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PREFACE 



This manual describes the processors used in the Multics system. These are 
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the GE-645) and DPS 8M, which refers to the DPS 8 family of Multics processors, 
i.e. DPS 8/70M, DPS 8/62M and DPS 8/52M. The reader should be familiar with 
the overall modular organization of the Multics system and with the philosophy 
of asynchronous operation. In addition, this manual presents a discussion of 
virtual memory addressing concepts including segmentation and paging. 

The manual is intended for use by systems programmers responsible for writing 
software to interface with the virtual memory hardware and with the fault and 
interrupt portions of the hardware. It should also prove valuable to programmers 
who must use machine instructions (particularly language translator implementors) 
and to those persons responsible for analyzing crash conditions in system dumps. 

This manual includes the processor capabilities, modes of operation, functions, 
and detailed descriptions of machine instructions. Data representation, 
program-addressable registers, addressing by means of segmentation and paging, 
faults and interrupts, hardware ring implementation, and cache operation are 
also covered. 

Changes and Additions 

Section 3 has been revised to include register information pertaining to 
the DPS 8M processor. 



The information and specifications in this document are 
subject to change without notice. This document contains 
information about Honeywell products or services that may 
not be available outside the United States. Consult your 
Honeywell Marketing Representative. 
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SECTION 1 
INTRODUCTION 



The processor described in this reference manual is a hardware module 
designed for use with Hultics. The many distinctive features and functions of 
Multics are enhanced by the powerful hardware features of the processor. The 
addressing features, in particular, are designed to permit the Multics software 
to compute relative and absolute addresses, locate data and programs in the 
Multics virtual memory, and retrieve such data and programs as necessary. 



MULTICS PROCESSOR FEATURES 

The Multics processor contains the following general features: 

1. Storage protection to place access restrictions on specified segments. 

2. Capability to interrupt program execution in response to an external 
signal (e.g., I/O termination) at the end of any even/odd instruction 
pair (midinstruction interrupts are permitted for some instructions), 
to save processor status, and to restore the status at a later time 
without loss of continuity of the program. 

3. Capability to fetch instruction pairs and to buffer two instructions 
(up to four instructions, depending on certain main memory overlap 
conditions) including the one currently in execution. 

4. Overlapping instruction execution, address preparation, and 
instruction fetch. While an instruction is being executed, address 
preparation for the next operand (or even the operand following it) or 
the next instruction pair is taking place. The operations unit can be 
executing instruction N, instruction N+1, can be buffered in the 
operations unit (with its operand buffered in a main memory port) , and 
the control unit can be executing instructions N+2 or N+3 (if such 
execution does not involve the main memory -port or registers of 
instructions N or N+1) or preparing the address to fetch instructions 
N+4 and N+5. This includes the capability to detect store 
instructions that alter the contents of buffered instructions and the 

• ability to delay preprocessing of an address using register 
modification if the instruction currently in execution changes the 
register to be used in that modification. 

5. Interlacing capability to direct main memory accesses to interlaced 
system controller modules. 

6. Intermediate storage of address and control information in high-speed 
registers addressable by content (associative memory). 

7. Intermediate storage of base address and control information in 
pointer registers that are loaded by the executing program. 

8. Absolute address computation at execution time. 
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9 * SH 1 ^ ^ -, h °l d r «f entl y referenced operands and instructions in a 
nigh-speed look-aside memory (cache option). 

Segmentation and Paging 

wmuJi segment is a collection of data or instructions that is assigned a 
?S ,v,f name and ^dressed symbolically by the user. Paging is controlled by 
the system software; the user need not be aware of the existence of pages! 
User-visible address preparation is concerned with the calculation of a virtual 
memory address; the processor hardware completes address preparation by 
iSSSl* '"^ the final V rtUal memory add "ss into an absolute main memory 
m-?n IV U , S «. er m c a y u view each of ni s segments as residing in an independent 

7™«n,? ° ry Uni ^ EaCh s J?8 n,ent has i^ own origin that can be addressed as 
location zero. The size of each segment varies without affecting the addressing 
of the other segments. Each segment can be addressed like a conventional main 
-ry image starting at location zero. Maximum segment size is 262,144 words 



memo 



When viewed from the processor, main memory consists of blocks or Daee 

ft???*: ?« inSl Whi w h ha c a . le " gth of "P a ge-size» words. The page size used by 

i i «i S words. Each frame begins at an absolute address which is zero 

™i° r^^ 86 ^ 126 * Any page ° f a se « ment can b e Placed in any available main 
memory frame. These pages may be addressed as if they were contiguous, even 
though they may be in widely scattered absolute locations. Only currently 
referenced pages need be in main memory. A segment need not be paged, in which 
case the complete segment is located in contiguous words of main memory. In 
Multics, all user segments are paged. See Section 5 for additional discussion. 

Address Modification and Address Appending 

Before each main memory access, two major phases of address preparation 
take place: ^ K 

1. Address modification by register or indirect word content, if 
specified -by the instruction word or indirect word. 

2. Address appending, in which a virtual memory address is translated 
into an absolute address to access main memory. 

Although the above two types of modification are combined in most 
operations, they are described separately in Sections 5 and 6. The address 
modification procedure can go on indefinitely, with one type of modification 
leading to repetitions of the same type or to other types of modification prior 
to a mam memory access for an operand. 



Faults and Interrupts 

The processor detects certain illegal instruction usages, faulty 
communication with the main memory, programmed faults, certain external events, 
and arithmetic faults. Many of the processor fault conditions are deliberately 
or inadvertently caused by the software and do not necessarily involve error 
conditions. The processor communicates with the other system modules (I/O 
multiplexers, bulk store controllers, and other processors) by setting and 
answering external interrupts. When a fault or interrupt is recognized, a 
"trap" results. The trap causes the forced execution of a pair of instructions 
in a main memory location, unique to the fault or interrupt, known as the fault 
or interrupt vector. The first of the forced instructions may cause safe 
storage of the processor status. The second instruction in a fault vector 
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should be some form of transfer, or the faulting program will be resumed at the 
point of interruption. Faults and interrupts are described in Section 7. 

Interrupts and certain low-priority faults are recognized only at specific 
times during the execution of an instruction pair. If, at these times, bit 28 
in the instruction word is set ON, the trap is inhibited and program execution 
continues. The interrupt or fault signal is saved for future recognition and is 
reset only when the trap occurs. 



PROCESSOR MODES OF OPERATION 

There are three modes of main memory addressing (absolute mode, append 
mode, and BAR mode), and two modes of instruction execution (normal mode and 
privileged mode). 



Instruction Execution Modes 



NORMAL MODE 



Most instructions can be executed in the normal mode. Certain 
instructions, classed as privileged, cannot be executed in normal mode. These 
are identified in the individual instruction descriptions. An attempt to 
execute privileged instructions while in the normal mode results in an illegal 
procedure fault. The processor executes instructions in normal mode only if it 
is forming addresses in append mode and the segment descriptor word (SDW) for 
the executing segment specifies a nonprivileged procedure. 



PRIVILEGED MODE 



In privileged mode, all instructions can be executed. The processor 
executes instructions in privileged mode when forming addresses in absolute mode 
or when forming addresses in append mode and the segment descriptor word (SDW) 
Tor the segment in execution specifies a privileged procedure and the execution 
ring is equal to zero. See Sections 5 and 7 for additional discussion. 



Addressing Modes 



ABSOLUTE MODE 



In absolute mode, the final computed address- is treated as the absolute 
main memory address unless the appending hardware mechanism is invoked for a 
particular main memory reference. During instruction fetches, the procedure 
pointer register is ignored. The processor enters absolute mode when it is 
initialized or immediately after a fault or interrupt. It remains in absolute 
mode until it executes a transfer instruction whose operand is obtained via 
explicit use of the appending hardware mechanism. 



The appending hardware mechanism may 
setting bit 29 of the instruction word ON 
loaded pointer register or by the use 
indirect-to-pointer (itp) modification in an 



be invoked for an instruction by 
to cause a reference to a properly 
of indirect-to-segment (its) or 
indirect word. 
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APPEND MODE 

The append mode is the most commonly used main memory addressing mode. In 
append mode the final computed address is either combined with the procedure 
pointer register, or it is combined with one of the eight pointer registers. If 
bit 29 of the instruction word contains a 0, then the procedure pointer register 
is selected; otherwise, the pointer register given by bits 0-2 of the 
instruction word is selected. 



BAR MODE 



In BAR mode, the base address register (BAR) is used. The BAR contains an 
address bound and a base address. All computed addresses are relocated by 
adding the base address. The relocated address is combined with the procedure 
pointer register to form the virtual memory address. A program is kept within 
certain limits by subtracting the unrelocated computed address from the address 
bound. If the result is zero or negative, the relocated address is out of 
range, and a store fault occurs. 



PROCESSOR UNIT FUNCTIONS 

Major functions of each principal logic element are listed below and are 
described in subsequent sections of this manual. 



Appending Unit 

Controls data input/output to main memory 
Performs main memory selection and interlace 
Does address appending 
Controls fault recognition 
Interfaces with cache 

Associative Memory Assembly 

This assembly consists of sixteen 51 -bit page table word associative memory 
(PTWAM) registers and sixteen 108-bit segment descriptor word associative memory 
(SDWAM) registers. These registers are used to hold pointers to most recently 
used segments (SDWs) and pages (PTWs). This unit reduces the need .for possible 
multiple main memory accesses before obtaining an absolute main memory address 
of an operand or instruction. 

Control Unit 

Performs address modification 

Controls mode of operation (privileged, normal, etc.) 

Performs interrupt recognition 
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Decodes instruction words and indirect words 
Performs timer register loading and decrementing 

Operation Unit 

Does fixed- and floating-binary arithmetic 
Does shifting and Boolean operations 

Decimal Unit 

Does decimal arithmetic 

Does character-string and bit-string operations 
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SECTION 2 
DATA REPRESENTATION 



INFORMATION ORGANIZATION 

The processor, like the rest of the Hultics system, is organized to deal 
with information in basic units of 36-bit words. Other units of 4-, 6-, 9-bit 
characters or bytes, 18-bit half words, and 72-bit word pairs can be manipulated 
within the processor by use of the instruction set. These bit groupings are 
used by the hardware and software to represent a variety of forms of coded data. 
Certain processor functions appear to manipulate larger units of 144, 288, 576, 
and 1152 bits, but these functions are performed by means of repeated use of 
72-bit word pairs. All information is transmitted, stored, and processed as 
strings of binary bits. The data values are derived when the bit strings are 
interpreted according to the various formats discussed in this section. 

POSITION NUMBERING 

The numbering of bit positions, character and byte positions, and words 
increases from in the direction of conventional reading and writing: from the 
most significant to the least significant digit of a number, and from left to 
right in conventional alphanumeric text. 

Graphic presentations in this manual show registers and data with position 
numbers increasing from left to right. 



NUMBER SYSTEM 

The binary arithmetic functions of the processor are implemented in the 
twos complement, binary number system. One of the primary properties of this 
number system is that a field (or register) having width, n bits may be 
interpreted in two different ways; the logical case and the arithmetic or 
algebraic case. 

( 

In the logical case, the number is unsigned, positive, and lies in the 
range [0,211-1] where n is the size of the register or the length of the field. | 
The results of arithmetic operations on numbers for this case are interpreted as 
modulo 2i± numbers. Overflow is not defined for this case since the range of the 
field or register cannot be exceeded. The numbers and 2—-1 are consecutive 
(not separated) in the set of numbers defined for the field or register. 

/ IOx the arithmetic case, the number is signed and lies in the range 
[_ 2 vn-u j2 ».n-u_ 1 ] ^ Overflow is defined for this case since the range can be 
exceeded in either direction (positive or negative). The left-hand-most bit of 
the field or register (bit 0) serves as the sign bit and does not contribute to 
the magnitude of the number. 



2-1 AL39 



I 



aKrorShmriL 3 ^ 3 " 1 ; 386 ° f thiS ira P^ m entation is that the hardware arithmetic 
algorithms for the two cases are identical; the only distinction lying in the 

"iL a r tl0n V V 16 reSUlts by the user ' Instruction set features are 
T£inl\ f /°f De !\ fon \ in « binar y arithmetic with overflow disabled (the so-called 
logical instructions) and for comparing numbers in either sense. 

Subtraction is performed by adding the twos complement of the subtrahend to 
the minuend. (Note that when the subtrahend is zero the algorithm for forming 

is zerT S5 P i!:Stf *»- rt111 ° a " ied out » but ' »"«• ^e twos 8 complement e" 

is zero, the result is correct.) 

,.«nJ^°^ her im P° rtant , feature of the twos complement number system (with 
, h s P ec J f ?° comparison of numeric values) is that the no borrow condition in true 
subtraction is identical to the carry condition in true addition and vice versa 

A statement on the assumed location of the binary point has significance 

?£ 7 J?Eh!!!lM t i Plleati | 0n K - ;S ^vision. These two operations are implanted for 

sitT n n n flM i0 b0t < h "*•««• «<> faction modes. Integer means that the 

h?? ^?*f K b 2*? ry ? 0in £ is assumed to th « right of the least significant 

bit position, that is, to the right of the right-hand-most bit of the field or 

rX I ?U£*«? 1 ? h fractl ° n ™ ea " that th « Position of the binary point is "assumed to 
«? fif « °L e m °9t significant bit position, that is, between bit and bit 1 
of the field or register (recall that bit is the sigh bit). 

INFORMATION FORMATS 

The figures that follow show the unstructured formats (templates) for the 
various information units defined for the processor. Data transfer between the 
processor and mam memory is word oriented; a 36-bit machine word is transferred 
for single-precision operands and subfields of machine words, and a 72 -bit word 

KJ«h-i S K^ anSf V r ^ f0 I a11 other cases Multiword operands, instruction 

ZaI h u V? d character-string operands, etc.). The information unit to be 

used and the data transfer mode are determined by the processor according to the 

function to be performed. 

a HHn™Ki 36 " b ^ t «. UnSl l r , UCtUred , machine w ord shown in Figure 2-1 is the minimum 
addressable information unit in main memory. Its location is uniquely 
determined- by its mam memory address, Y. All other information units are 
defined relative to the 36-bit machine word. 




Figure 2-1. Unstructured Machine Word Format 



Two consecutive machine words as shown in Figure 2-2, the first having an 
even main memory address, form a 72-bit word pair. In 72-bit word pair data 
transfer mode, the word pair is uniquely located by the main memory address of 
either of its constituent 36-bit machine words. Thus, if Y is even, the word 
pair at (Y,Y+1) is selected. If Y is odd, the word pair at (Y-1.Y) is selected. 
The term Y-pair is used when referring to such a word pair. 
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3 3 



7 

1 



Even word 



36 



36 



Odd word 



Figure 2-2. Unstructured Word Pair Format 



Four-bit bytes are mapped onto 36-bit machine words as shown in Figure 2-3. 
The bits at bit positions 0, 9, 18, and 27 are forced to be by the processor 
on data transfers to main memory and are ignored on data transfers from main 
memory. 





















1 


1 


1 


1 


1 


1 


2 


2 


2 


2 


2 


3 


3 


3 


1 


4 5 


8 Q- 


3 4 


7 8 


2 ^ 


6 7 8 


1 2 


5 



















• 












4 1 



4 1 



4 1 



Figure 2-3- Unstructured 4-bit Byte Format 
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Six-bit characters are mapped onto 36-bit machine words as shown in Figure 












1 1 
1 2 



1 1 
7 8 



2 2 



2 3 
Q 



3 

5 



Figure 2-4. Unstructured 6-bit Character Format 



Nine-bit bytes are mapped onto 36-bit machine words as shown in Figure 2-5. 












1 1 

11 



2 2 



Figure 2-5. Unstructured 9-bit Byte Format 



Eighteen-bit half words are mapped onto 36-bit machine words as shown in 
Figure 2-6. 
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Upper half Lower half 

Figure 2-6. Unstructured 18-bit Half Word Format 



DATA PARITY 

Odd parity on each 36-bit machine word transferred to main memory is 
generated as it leaves the processor, is verified at several points along the 
transmission path, and is held in main memory either as an extra bit in the case 
of magnetic core memory or as part of the error detecting and correcting (EDAC) 
code in the case of magnetic oxide semiconductor (MOS) memory. If an incorrect 
parity is detected at any of the various parity check points, the main memory 
returns an illegal action signal and a code appropriate to the check point. 

On data transfers from main memory, the parity information is retrieved and 
transmitted with the data information. The same verification checks are made 
and illegal action signalled for errors. The processor makes a final parity 
check as the data enters the processor. 

Any detected parity error causes the processor parity indicator to be set 
ON and (if enabled) a parity fault occurs. 



REPRESENTATION OF DATA 

Data is defined by imposing an operand structure on the information units 
just described. Data is represented in two forms: numeric or alphanumeric. The 
form is determined by the processor according to function to be performed. 

In the definitions below, a ± is the value of the bit in the i th bit 
position, either or 1 . 



Numeric Data 

Numeric data is represented in three modes: fixed-point binary, 
floating-point binary, and decimal. The mode is determined by the processor 
according to the function being performed. 



FIXED-POINT BINARY DATA 



Fixed-Point Binary Integers 

Fixed-point binary integer data is defined by imposing either of the bit 
position value expressions shown below on an information unit of n bits. 
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Logical value: 

a x2<H- 1) + ai x2 (n - 2) * 



+ a 



iX2 (n-i-1) + 



+ a 



n-1 



Arithmetic value: 

-a x2 ( H- 1 ) + a lX 2 ( H- 2) + 



+ a l x2 (n -- i - 1) + ... + a n _, 



The following fixed-point binary integer data items are defined (also see 
Table 2-1 for values): 



Operand 
size(bits) 

6 

9 

18 

36 

72 



Operand name 

6-bit character operand 
9-bit byte operand 
Half word operand 
Single-precision operand 
Double-precision operand 



Note that a 4-bit operand is not defined. This data item is defined only 
for decimal data. (See discussion of decimal data later in this section). 

The proper operand and its position with respect to a 36-bit machine word 
are determined by the processor during preparation of the main memory address 
for the operand. If the data width of the operand selected is smaller than the 
register involved, the operand is high- or low-order zero filled as necessary. 

The values in Table 2-1 are given in terms of the operand sizes. The value 
an operand contributes to a larger field or register depends on the alignment of 
the operand with respect to the field or register. 



Table 2-1. Fixed-Point Binary Integer Values 



Operand 


6-bit 
character 


9-bit 
byte 


18-bit 
half word 


36-bit 
single 
precision 


72-bit 
double 
precision 


Logical 
minimum 
maximum 
resolution 


2 6 -1 
1 


1 


2 1§ -1 
1 


23^., 

1 


2^-1 
1 


Arithmetic 

minimum 

maxima 
negative 
positive 

resolution 




2 5 -1 
1 




8 28 
2 B -1 

1 




2 1 7_1 
1 




_ 2 35 
235_! 

1 




-? 71 
2^-1 

1 



Fixed-point Binary Fractions 

lixed-point binary fraction data is defined by imposing the bit position 
value expression below on an information unit of n bits. 
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Arithmetic value: 

-a Q + a 1 x2~ 1 + a 2 x2" 2 + ... + a i x2" i — + a n _ 1 x2~^- -1 ' 



data. 



Note that logical values are not defined for fixed-point binary fraction 



The following fixed-point binary fraction data items are defined (also see 
Table 2-2 for values) : 



Operand 
size(bits) 

6 
9 

18, 
36 

72 



Operand name 

6-bit character operand 
9-bit byte operand 
Half word operand 
Single-precision operand 
Double-precision operand 



Note that a 4-bit operand is not defined. This data item is defined only 
for decimal data. (See discussion of decimal data later in this section.) 
Fixed-point binary fraction operands are used by the Divide Fraction (dvf) and 
Multiply Fraction (mpf) instructions only. 

The proper operand and its position with respect to a 36-bit machine word 
are determined by the processor during preparation of the main memory address 
for the operand. If the data width of the operand selected is smaller than the 
register involved, the operand is high- or low-order zero filled as necessary. 

The values in Table 2-2 are given in terms of the operand sizes. The value 
an operand contributes to a larger field or register depends on the alignment of 
the operand with respect to the field or register. 



Table 2-2. Fixed-Point Binary Fraction Values 











36-bit 


72-bit 


Operand 


6-bit 


9-bit 


18-bit 


single 


double 




character 


byte 


half word 


precision 


precision 


Arithmetic 












minimum 

















maxima 












negative 


~ 1 - c 


-1.0 Q 


-1.0 


-1.0 „ 


-1.0 _. 


positive 


1.0-2-5 


1.0-2 -8 


'■PK 


u p% 


1 -?:?i 71 


resolution 


2 -5 


2 -8 



FLOATING-POINT BINARY DATA 



A floating-point binary number is expressed as: 



Z = M x 2 e 
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where: 

M is a fixed-point binary fraction; the mantissa 
E is a fixed-point binary integer; the exponent 

A floating-point binary number is defined by partitioning an information 
unit of n bits into two pieces; an 8-bit fixed-point binary integer exponent and 
an (n-8)-bit fixed-point binary fraction mantissa. 

The following floating-point data items are defined. 



Operand 
size(bits) 

18 
36 
72 



Operand name 

Half word operand 
Single-precision operand 
Double-precision operand 



For clarity, the formats of these operands are shown in Figure 2-7 through 
Figure 2-9. In the figures, the fields labeled S hold sign bits associated with 
the exponent, E, and the mantissa, M. 

The floating-point binary operands are used only by the floating-point 
binary arithmetic instructions (see Section 4). The 18-bit half word operand 
has meaning only when used in conjunction with the direct upper (du) address 
modification (see Section 6 for a discussion of address modification). 




1 




7 8 9 



7 1 



3 



Figure 2-7. Eighteen-bit Half Word Floating-Point Binary Operand Format 




1 




7.8,9 



7 1 



27 



Figure 2-8. Single-Precision Floating-Point Binary Operand Format 




1 




78_9_ 



7 1 



—63 



Figure 2-9. Double-Precision Floating-Point Binary Operand Format 
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The proper operand is selected by the processor during preparation of the 
main memory address for the operand. 



Overlength Registers 

The AQ-register is used to hold the mantissa of all flo'ating-point binary 
numbers. The AQ-register is said to be overlength with respect to the operands 
since it has more bits than are provided by the operands. Operands are low-order 
zero filled when loaded and low-order truncated (or rounded, depending on the 
instruction) when stored. Thus, the result of all floating-point instructions 
has more bits of precision in the AQ-register than may be stored. 

Users are cautioned that calculations involving floating-point operands may 
suffer from propagation of truncation errors even if the computation algorithms 
are designed to hold mantissas in the AQ-register as long as possible. It is 
possible to retain full AQ-register precision of intermediate results if they 
are saved with the Store AQ (staq) and Store Exponent (ste) instructions but 
such saved data are not usable as a floating-point operand. 



Normalized Numbers 

A floating-point binary number is said to be normalized if the relation 
I -0.5 > M > -1 or 0.5 < M <1 or [M=0 and E=-128] 

I is satisfied. This is a result of using a 2's complement mantissa. Bits 8 and 
9 are different unless the number is zero. The presence of unnormalized numbers 
in any finite mantissa arithmetic can only degrade the accuracy of results. For 
example, in an arithmetic allowing only two digits in the mantissa, the number 
0.005x10^ has the value zero instead of the value one-half 

Normalization is a process of shifting the mantissa and adjusting the exponent 
until the relation above is satisfied. Normalization may be used to recover 
some or all of the extra bits of the overlength AQ-register after a floating-point 
operation. 

There are cases where the limits of the registers force the use of unnormalized 
numbers. For example, in an arithmetic allowing three digits of mantissa and 
one digit of exponent, the calculation 0.3x10 -TO - 0.1x10 -1 ' (the normalized 
case) may not be made, but 0.03x10 -y - 0.001x10 -9 = 0.029x10 -9 (the unnormalized 
case) is a valid result. 



are: 



Some examples of normalized and unnormalized floating-point binary numbers 

Unnormalized positive binary 0.00011010 x 2? 
Same number normalized 0.11010000 x 2** 
Unnormalized negative binary 1.11010111 x 2"'* 
Same number normalized 1.01011100 x 2~*> 

The minimum normalized nonzero floating-point binary number is 2~ 12 " in all 
cases. Table 2-3 gives the values for the floating-point binary operands. 
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Table 2-3. Floating-Point Binary Operand Values 



Operand 

Unnormalized 

minimum 

maxima 

negative 

positive 

resolution 


18-bit 
half word 

(a) 

- 1.0x2 1 27 , 7 
(1-2- 9 )x2;27 
1:9 Tb) 


36-bit 
single 
precision 

(a) 

-1.QX2 12 7 

( 1-2-2' )x22f 7 
1:27 Tb) 


72-bit 
double 
precision 

(a) 

-1.0x2 12 7 
(1-2- 63 )x2 12 7 

1:63 (b7 



(a) There is no unique representation for the value zero in floating-point 
binary numbers; any number with mantissa zero has the value zero. However, 
the processor treats a zero mantissa as a special case in order to preserve 
precision in later calculations with a zero intermediate result. Whenever 
the processor detects a zero mantissa as the result of a floating-point 
binary operation, the AQ-register is cleared to zeros and the E register is 
set to -128. This representation is known as a floating-point normalized 
zero. The unnormalized zero (any zero mantissa) will be handled correctly 
if encountered in an operand but precision may be lost. For example, 
Ax10 -1M + 0x10 85 will not produce desired results W*ce all the precision 
of A will be lost when it is aligned to match the 10" exponent of the 0. 



(b) A value cannot be given for resolution in these cases since such a value 
depends on the value of the exponent, E. The notation used, 1 :m, indicates 
resolution to 1 bit in a field of m. Thus, the following general statement 
on resolution may be made: 

The resolution of a floating-point binary operand with mantissa 
length m and exponent value E is 2 { - E ~- } . 



DECIMAL DATA 



Decimal numbers are expressed in the following forms: 
Fixed-point, no sign MMMMMM. 

Fixed-point, leading sign +MMMMMM. 

Fixed-point, trailing sign MMMMMM. • 



Floating-point 



+MMMMMM.X10 1 



The form is specified by control information in the operand descriptor for 
the operand as used by the Extended Instruction Set (EIS) instructions (see 
Section 4 for a discussion of the EIS instructions). 

A decimal number is defined by imposing any of the byte position value 
expressions below on a 4- or 9-bit byte information unit of length n bytes. 



Fixed-point, no sign: 

c x10 ( £- 1) + CjXlO^" 2 * + ... + c^.t) 
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Fixed-point, leading sign: 

[sign=c 3 Cl x10<n- 2 > + c 2 x10<n-3> + ... + e (n „ 1} 

Fixed-point, trailing sign: 

c x10<n-2> + 0lX io(n-3) + ... + C( ^_ 2) [sign=e (iJ . 1 ,] 

Floating-point: 

[sign=c ] Cl x10(J2-3) + C2 x10(n- 4 ) + ... + e (n _ 3) Cexponent=8 bits] 



where: 



c ± is the decimal value of the byte in the i tn byte position. 

[signsc^ indicates that o t is interpreted as a sign byte. 

[exponent=8 bits] indicates that the exponent value is taken from the 
last 8 bits of the string. If the data is in 9-bit bytes, the 
exponent is bits 1-8 of c ( 1} . If the data is in 4-bit bytes, the 



exponent is the binary value of the concatenation of c, ? ! and 
c (n-1)- { -' 

^ *, T D e decimal number as described above is the only decimal data item 
defined. It may begin on any legal byte boundary (without regard to word 
boundaries) and has a maximum extent of 63 bytes. 

The processor handles decimal data as 4-bit bytes internally. Thus, 9-bit 
bytes are high-order truncated as they are transferred from main memory and 
high-order filled as they are transferred to main memory. The fill pattern is 
"0001 1»b for digit bytes and "0001 0" for sign bytes. The floating-point 
exponent is a special case and is treated as a fixed-point binary integer. 

The processor performs validity checking on decimal data. Only the byte 
values [0,11]g are legal in digit positions and only the byte values [12,17] Q 
are legal in sign positions. Detection of an illegal byte value causes an 
illegal procedure fault, — 
Table 2-4. 



The interpretation of decimal sign bytes is shown in 



Table 2-4. Decimal Sign Character Interpretation 



9-bit 


4-bit 




bytes 


bytes 


Interpretation 


52 8 


12 8 


+ 


53 8 <*> 


13 8 <» 


+ 


54 8 


14 8 <a) 


+ 


55 8 <a> 


V a) 


- 


56 8 


16 8 


+ 


57 8 


17 8 


+ 
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(a) 



(b) 



This value is used as the default sign byte for storage Of results. The 
presence of other values will yield correct results according to the 
interpretation. 

An optional control bit in the EIS decimal arithmetic instructions (see 
Section II) allows the selection of 13b for the plus sign byte for storage 
of results in 4-bit data mode. 



Decimal Data Values 




Table 2-5 for decimal data operand values. 



Table 2-5. Decimal Data Values 



Operand 

Arithmetic 
minimum 

maximum 
resolution 



Fixed-point 
unsigned 







(10 63 -1)x10 
(b) 



31 



1:SF 



Fixed-point 
signed 



(10 



(a) 
62 -1)x10 31 
1:SF (b) 



Floating-point 
9-bit 



(a) 

6l -1)x10 158 
(c) 



+ (10 

1:SF+E 



Floating-point 
U-bit 



+ (10 

1 



(a) : 

60_ 1)x1Q 158 
:SF+E (c) 



(al As in floating-point binary arithmetic, there is no unique representation 
of the value zero except in the case of fixed-point, unsigned data. Therefore, 
the processor detects a zero result and forces a value of +0. for fixed-point, 
signed data and +0.x10?2? for floating-point data. Again, as in [1°*^:^ 
binary arithmetic, other representations of the value zero will be handled 
correctly except for possible loss of precision during operand alignment. 

(b) A value cannot be given for resolution in these cases since such a value 
depends on the value of the scaling fap±J?r, SF. The notation used, . 1-SF, 
indicates resolution to 1 part in 10^ f5 . Thus, the following general 
statement on resolution may be made: 

The resolution of a fixed-point decimal operand with scaling factor 
SF is 10 sF \ 

(c) A value cannot be given for resolution in these cases since such a value 
depends on the values of the scaling factor, SF and the exppgen£ E. The 
notation used, V.SF+E, indicates resolution to 1 part in 10^ . Thus, 
the following general statement on resolution may be made: 

The resolution of a floaUng-point decimal operand with scaling factor 
SF and exponent E is 10 bt . 
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Alphanumeric Data 

Alphanumeric data is represented in two modes; character-string and 
bit-string. The mode is determined by the processor according to the function 
being performed. 



CHARACTER STRING DATA 

Character string data is defined by imposing the character position 
structure below on a 4-bit, 6-bit, or 9-bit information unit of length n bytes 
or characters. 

C || c 1 || ••• || c (n-1> 

where: 

Cj is the character in the i th character position. 
11 indicates the concatenation operation. 

The character string described above is the only character string data item 
defined. It may begin on any legal character boundary (without regard to word 
boundaries) and has a maximum extent as shown in Table 2-6. 



Table 2-6. Character String Data Length Limits 



Character size 

9-bit 
6-bit 
4-bit 



Length limit 

1048576 
1572864 
2097152 



No interpretation of the characters is made except as specified for the 
instruction being executed (see Section 4). 



BIT STRING DATA 

Bit string data is defined by imposing the bit position structure below on 
a bit information unit of length n bits. 



b o|l b l|| — || b (n-1) 



where: 



bj is the value of the bit in the i th position, 
H indicates the concatenation operation. 
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The bit string described above is the only bit string data item defined. 
It may begin at any bit position (without regard to character or word 
boundaries) and has a maximum extent of 9137184 bits. 
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SECTION 3 



PROGRAM ACCESSIBLE REGISTERS 



A processor register is a hardware assembly that holds information for use 
in some specified way. An accessible register is a register whose contents are 
available to the user for his purposes. Some accessible registers are explicitly 
addressed by particular instructions, some are implicitly referenced during the 
course of execution of instructions, and some are used in both ways. The accessible 
registers are listed in Table 3-1. See Section 4 for a discussion of each 
instruction to determine the way in which the registers are used. 



Table 3-1- Processor Registers 







Length 




Register name 


Mnemonic 


(bits) 


Quantity 


Accumulator Register 


A 


36 


1 


Quotient Register 


Q 


36 


1 


Accumulator-Quotient Register^ 3 ' 


AQ 


72 


1 


Exponent Register 


E 


8 


1 


Exponent- Accumulator-Quotient Register ( a ^ 


EAQ 


80 


1 


Index Registers 


Xn 


18 


8 


Indicator Register 


IR 


14 


1 


Base Address Register 


BAR 


18 


1 


Timer Register 


TR 


27 


1 


Ring Alarm Register 


RALR 


3 


1 


Pointer Registers 


PRn 


42 


8 


Address Registers 


ARn 


24 


8 


Procedure Pointer Register; 1 ^ 
Temporary Pointer Register^ 


PPR 


37 


1 


TPR 


42 


1 


Descriptor Segment Base Register 


DSBR 


51 


1 


Segment Descriptor Word Associative Memory 


SDWAM 


88 


16 


Page Table Word Associative Memory 


PTWAM 


51 


16 


Fault Register 


FR 


35 


1 


Mode Register 


MR 


33 


1 


Cache Mode Register 


CMR 


28 


1 


Control Unit (CU) History Register 




72 


16 


Operations Unit (OU) History Register 




72 


16 


Decimal Unit (DU) History Register 




72 


16 


Appending Unit (APU) History Register 




72 


16 


Configuration Switch Data 




36 


5 


Control Unit Data 




288 


1 


Decimal Unit Data 


1 


288 


1 



(a) This register is not a separate physical assembly but is a combination of 
its constituent registers. 
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(b) This register is not explicitly addressable, but is included because of its 
vUalrolfndDPS 8M«/ p p 98fl.982P-976.986P in instruction and operand 
address preparation. 

In the descriptions that follow, the diagrams given for ^f^^^xSlts? 
not imply that a physical assembly possessing the pictured bit pattern exists. 
The diagram is a graphic representation of the form of the "S"*^ d *taas it 
appears in main memory when the register contents are stored or how data bits 
must be assembled for loading into the register. 

If the diagrams contain the characters "x" or "0". the values .of t^bits 
in the positions shown are irrelevant to the register. Bits P«tured as x are 
noi- ehansed when the register is stored. Bits pictured as "0" are set to when 
the register ^stored ^Neither »x" bits or -0" bits are loaded into the register. 



ACCUMULATOR REGISTER (A) 



Format: - 36 bits 



1 1 
78 



A-Upper 



A-Lower 



18 



TS 



Figure 3-1. Accumulator Register (A) Format 

Description : 

A 36-bit physical register located in the operations unit. 

Function : 

In fixed-point binary instructions, holds operands and results. 

In floating-point binary instructions, holds the most significant part of 
the mantissa. 

In shifting instructions, holds original data and shifted results. 

In address preparation, may hold two logically independent word offsets, 
A-upper and A-lower, or an extended range bit- or character-string length. 



2/82 



3-2 



AL39B 



QUOTIENT REGISTER (Q) 



Format: - 36 bits 



1 1 

JJL 



Q-Upper 



Tff 



Q-Lower 



IS 



Figure 3-2. Quotient Register (Q) Format 



Description : 



A 36-bit physical register located in the operations unit. 



Function: 



In fixed-point binary instructions, holds operands and results. 

In floating-point binary instructions, holds the least significant part of 
the mantissa. 

In shifting instructions, holds original data and shifted results. 

In address preparation, may hold two logically independent word offsets, 
Q-upper and Q-lower, or an extended range bit- or character-string length. 



ACCUMULATOR-QUOTIENT REGISTER (AQ) 



Format: - 72 bits 



3 3 



Even Word 



"3T 



Odd Word 



is 



Figure 3-3. Accumulator-Quotient Register (AQ) Format 



Description : 



A combination of the accumulator (A) and quotient (Q) registers. 
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Function ; 

In fixed-point binary instructions, holds double-precision operands and 
results. 

In floating-point binary instructions, holds the mantissa. 

In shifting instructions, holds original data and shifted results. 

EXPONENT REGISTER (E) 



Format: - 8 bits 





7 8 



exponent 



0000000000000000000000000000 



"2ff 



Figure 3-4. Exponent Register (E) Format 



Description; 



An 8-bit physical register located in the operations unit. 



Function: 



In floating-point binary instructions, holds the exponent. 



EXPONENT-ACCUMULATOR-QUOTIENT REGISTER (EAQ) 



Format: - 80 bits 





p, 





7 



8 




7 

1 


exponent 


mantissa 






8 






64 



Figure 3-5. Exponent-Accumulator-Quotient Register (EAQ) Format 



Description : 



A combination of the exponent (E), accumulator (A), and quotient (Q) registers. 
Although the combined register has a total of 80 bits, only 72 are involved 
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in transfers to and from main memory. The 8 low-order bits are discarded 
on store and zero-filled on load. 



Function: 



In floating-point binary instructions, holds operands and results. 



INDEX REGISTERS (Xn) 



Format: - 18 bits each 



18 



Description : 



Figure 3-6. Index Register (Xn) Format 



Eight 1 8-bit physical registers in the operations unit numbered through 
7. Index register data may occupy the position of either an upper or lower 
18-bit half-word operand (see Section 2). 



Function: 



In fixed-point binary instructions, hold half-word operands and results. 

In address preparation, hold word offsets or extended range bit- or 
character-string lengths. 



INDICATOR REGISTER (IR) 



Format: 



It bits 



1112222222222333 3 

7 8 Q 1 ? 3 1 SJUZ _ 8 _ Q _° _ 1 _ 2 _ s 



xxxxxxxxxxxxxxxxxx 







18 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 



Figure 3-7. Indicator Register (IR) Format 
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Description: 



An assemblage of 15 indicator flags from various units of the processor. 
The data occupies the position of a lower 18-bit half word operand (see 
Section 2). When interpreted as data, a bit value of 1 corresponds to the 
ON state of the indicator, a bit value of corresponds to the OFF state. 



Function: 



The functions of the individual indicator bits are given below. An "x" in 
the column headed "L" indicates that the state of the indicator is not 
affected by instructions that load the IR. 



key L Indicator name 
a Zero 



Negative 



Carry 



Overflow 



Exponent overflow 



Action 

This indicator is set ON whenever the output 
of the main binary adder consists entirely of 
zero bits for binary or shifting instructions 
or the output of the decimal adder consists 
entirely of zero digits for decimal 
instructions; otherwise, it is set OFF. 

This indicator is set ON whenever the output 
of bit of the main binary adder has value 1 
for binary or shifting instructions or the 
sign character of the result of a decimal 
instruction is the negative sign character; 
otherwise, it is set OFF. 

This indicator is set ON for any of the following 
conditions; otherwise, it is set OFF. 

(1) If a bit propagates leftward out of bit 
of the main binary adder for any binary 
or shifting instruction. 

(2) If Jvaluelj =< |value2| for a decimal 
numeric comparison instruction. 

(3) If charl =< char2 for a decimal 
alphanumeric compare instruction. 

This indicator is set ON if the arithmetic 
range of a register is exceeded in a fixed-point 
binary instruction or if the target string of 
a decimal numeric instruction is too small to 
hold the integer part of the result. It remains 
ON until reset by the Transfer On Overflow 
(tov) instruction or is reset by some other 
instruction that loads the IR. The event that 
sets this indicator ON may also cause an overflow 
fault. (See overflow mask indicator below.) 

This indicator is set ON if the exponent of 
the result of a floating-point binary or decimal 
numeric instruction is greater than +127. It 
remains ON until reset by the Transfer On 
Exponent Overflow (teo) instruction or is reset 
by some other instruction that loads the IR. 
The event that sets this indicator ON may also 
cause an overflow fault. (See overflow mask 
indicator below.) 
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key L Indicator name 



Action 



Exponent underflow 



This indicator is set ON if the exponent of 
the result of a floating-point binary or decimal 
numeric instruction is less than -128. It 
remains ON until reset by the Transfer On 
Exponent Underflow (teu) instruction or is reset 
by some other instruction that loads the IR. 
The event that sets this indicator ON may also 
cause an overflow fault. (See overflow mask 
indicator below.) 



Overflow mask 



Tally runout 



This indicator is set ON or OFF only by the 
instructions that load the IR. When set ON, 
the IR inhibits the generation of the fault 
for those events that normally cause an overflow 
fault. If the overflow mask indicator is set 
OFF after occurrence of an overflow event, an 
overflow fault does not occur even though the 
indicator for that event is still set ON. 
The state of the overflow mask indicator does 
not affect the setting, testing, or storing 
of any other indicator. 

This indicator is set OFF at initialization 
of any tallying operation, that is, any repeat 
instruction or any indirect then tally address 
modification. It is then set ON for any of 
the following conditions: 

(1) If any repeat instruction terminates 
because of tally exhaust. 

(2) If a Repeat Link (rpl) instruction 
terminates because of a zero link address. 



i Parity error 



j Parity mask 



k x Not BAR mode 



(3) If a tally exhaust is detected for an 
indirect then tally modifier. The 
instruction is executed whether or not 
tally exhaust occurs. 

CD If an EIS string scanning instruction 
reaches the end of the string without 
finding a match condition. 

This indicator is set ON whenever a system 
controller signals illegal action with a parity 
error code or the processor detects an internal 
parity error condition. The indicator is set 
OFF only by instructions that load the IR. 

This indicator is set ON or OFF only by the 
instructions that load the IR and is changed 
only when the processor is in privileged or 
absolute mode. When it is set ON, the IR 
inhibits the generation of the parity fault 
for all events that set the parity error 
indicator. If the parity mask indicator is 
set OFF after the occurrence of a parity error 
event, a parity fault does not occur even though 
the parity error indicator may still be set 
ON. The state of the parity mask indicator 
does not affect the loading, testing, or storing 
of any other indicator. 

This indicator is set OFF (placing the processor 
in BAR mode) only by execution of the Transfer 
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key L Indicator name 



Action 



Truncation 



and Set Slave (tss) instruction or by the operand 
data of the Restore Control Unit (rcu) 
instruction and is changed only when the 
processor is in privileged or absolute mode. 
It is set ON (taking the processor out of BAR 
mode) by the execution of any transfer 
instruction other than tss during a fault or 
interrupt trap. (See Section 7.) If a fault 
or interrupt trap occurs while in BAR mode 
and the IR is stored before any transfer occurs, 
then a Return (retl or Restore Control Unit 
(rcu) instruction that reloads the stored data 
will return the processor to BAR mode. 

This indicator is set ON whenever the target 
string of a decimal numeric instruction is 
too small to hold all the digits of the result 
or the target string of an alphanumeric 
instruction is too small to hold all the bits 
or characters to be stored. (Also see the 
overflow indicator for decimal numeric 
instructions.) The event that sets this 
indicator ON may also cause an overflow fault. 
(See overflow mask indicator above.) 



m Mid instruction 
interrupt fault 



This indicator is set OFF at the start of 
execution of each instruction and is set ON 
by the events described below. The indicator 
has meaning only when determining the proper 
restart sequence for the interrupted 
instruction. This indicator can be set on: 



(1) By any fault during execution of an EIS 
instruction; however, the state is 
safe-stored in the Control Unit Data only 
for access violation and directed faults. 

(2) By an interrupt signal during execution 
of those EIS instructions that allow very 
long operand strings. 

(3) If the processor is in absolute or 
privileged mode, by the execution of a 
Load Indicator Register (ldi), Return 
(ret), or Restore Control Unit (rcu) 
instruction with bit 30 set to 1 in the 
IR data. 



n x Absolute mode 



This indicator is set ON (placing the processor 
in absolute mode) when the processor is 
initialized and by execution of an nonappended 
transfer instruction during a fault or interrupt 
trap and is set OFF (placing the processor in 
append mode) by any execution of an appended 
transfer instruction. If the processor is not 
in absolute mode when the fault or interrupt 
occurs and the transfer instruction is Return 
(ret) or Restore Control Unit (rcu) and the 
appropriate mode bit is properly set in the 
IR data, the processor remains in its current 
mode. 



o Hex mode 



When the hexadecimal permission indicator (bit 
33 of the Mode Register) is set on and this 
indicator is also on, then the exponent of a 
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floating point number has a power of 16 rather 
than a power of two (binary floating point). 
The state of the hex mode indicator can be 
changed by executing a Load Indicator Register 
(ldi), Return (ret), or Restore Control Unit 
(rcu), instruction with the desired state (1 
or 0) set in bit 32 of the IR data. Hexadecimal 
mode is only available on DPS 8M processors. 
Indicator Register bit 32 is set to a zero 
value on DPS/L68 processors 



BASE ADDRESS REGISTER (BAR) 



Format: - 18 bits 




Figure 3-8. Base Address Register (BAR) Format 



Description : 



An 18-bit physical register in the control unit. 



Function: 



The Base Address Register provides automatic hardware Address relocation 
and Address range limitation when the processor is in BAR mode. 



BAR. BASE 



Contains the 9 high-order bits of an 18-bit address 
relocation constant. The low-order bits are generated 
as zeros. 



BAR. BOUND Contains the 9 high-order bits of the unrelocated address 
limit. The low-order bits are generated as zeros. An 
attempt to access main memory beyond this limit causes 
a store fault, out of bounds. A value of is truly 0, 
indicating a null memory range. 
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TIMER REGISTER (TR) 



Format: - 27 bits 



2 2 



Timer value 



27 



000000000 
9 



Figure 3-9. Timer Register (TR) Format 



Description: 



A 27-bit settable, free-running clock in the control unit. The value decrements 
at a rate of 512 kHz. Its range is 1.953125 microseconds to approximately 
1.37 minutes. 



Function: 



The TR may be loaded with any convenient value with the privileged Load 
Timer (ldt) instruction. When the value next passes through zero, a timer 
runout fault is signalled. If the processor is in normal or BAR mode with 
interrupts not inhibited or is stopped at an uninhibited Delay Until Interrupt 
Signal (dis) instruction, the fault occurs immediately. If the processor 
is in absolute or privileged mode or has interrupts inhibited, the fault is 
delayed until the processor returns to uninhibited normal or BAR mode or 
stops at an uninhibited Delay Until Interrupt Signal (dis) instruction. 



RING ALARM REGISTER (RALR) 



Format: - 3 bits 



3 3 3 

2^ 5. 



000000000000000000000000000000000 



RALR 



33 3 



Figure 3-10. Ring Alarm Register (RALR) Format 

Description : 

A 3-bit physical register in the appending unit. 
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Function: 



If the RALR contains a value other than zero and the effective ring number 
(see TPR.TRR below) is greater than or equal to the contents of the RALR 
and the instrucuction for which an absolute main memory address is being 
prepared is a transfer instruction, an access violation, ring alarm, fault 
occurs. Operating system software may use this register to detect crossings 
from inner rings to outer rings. 



POINTER REGISTERS (PRn) 



Format: - 42 bits each 



Even word of ITS pointer pair 







11 2 2 

.IJ SU- 



2 3 

JUL 







SNR 



RNR 



000000000 



<*3> 8 



15 



Odd word of ITS pointer pair 



3 
6 




5 


5 5 
4 6 


5 
7 




6 
2 


6 6 

3 5 


6 
6" 




7 
1 


WORDNO 





BITN0 





(TAG) 






18 


3 






6 


3 






6 



Data as stored by Store Pointer Register n Packed (sprpn) 



1 

5 6 7 


1 3 
8 5 


BITN0 


SNR 


WORDNO 



Figure 3-11. Pointer Register (PRn) Format 



Description : 



Eight combinations of physical registers from the appending unit and decimal 
unit numbered through 7. PRn. RNR, PRn. SNR, and PRn.BITNO are located in 
the appending unit and PRn. WORDNO is located in the decimal unit. The 
WORDNO registers also form part of the address registers discussed later in 
this section. 
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Function: 



The pointer registers hold information relative to the location in main 
memory of data items that may be external to the segment containing the 
procedure being executed. The functions of the individual constituent 
registers are: 



Register 
PRn.SNR 

PRn.RNR 

C43> 8 

PRn.WORDNO 
PRn.BITNO 

(TAG) 



Function 

The segment number of the segment containing the data 
item described by the pointer register. 

The final effective ring number value calculated during 
execution of the instruction that last loaded the PR. 

This field is not part of the PR but is generated each 
time the PR is stored as an ITS pair. 

The offset in words from the base or origin of the 
segment to the data item. 

The number of the bit within PRn.WORDNO that is the 
first bit of the data item. Data items aligned on word 
boundaries always have the value 0. Unaligned data items 
may have any value in the range [1,351. 

This field is not part of the PR but, in an ITS pointer 
pair, holds an address modifier for use in address 
preparation. 



ADDRESS REGISTERS (ARn) 



Format: 



24 bits each 



Data as stored by Store Address Register n (sarn) 









1 
7 


1 1 

? 9 


2 2 

3 


2 3 


WORDN0 


a 


BITNO 


000000000000 



Figure 3-12. Address Register (ARn) Format 



Description : 



Eight combinations of physical registers from the decimal unit numbered 
through 7. The W0RDN0 registers also form part of the pointer registers 
discussed earlier in this section. 



Function: 



Th.i address registers hold information relative to the location in main 
memory of the next bit, character, or byte of an EIS operand to be processed 



2/82 



3-12 



AL39B 



by an EIS instruction. The functions of the individual constituent registers 
are: 



key Register 

ARn.WORDNO 



ARn.CHAR 



ARn.BITNO 



Function 

The offset in words relative to the current addressing 

base referent (segment origin, BAR-BASE, or absolute 

depending on addressing mode) to the word containing 
the next data item element. 

The number of the 9-bit byte within ARn.WORDNO containing 
the first bit of the next data item element. 

The number of the bit within ARn.CHAR that is the first 
bit of the next data item element. 



NOTE: The reader's attention is directed to the presence of two bit number 
registers, PRn.BITNO and ARn.BITNO. Because the Multics processor was 
implemented as an enhancement to an existing design, certain apparent 
anomalies appear. One of these is the difference in the handling of 
unaligned data items by the appending unit and decimal unit. The 
decimal unit handles all unaligned data items with a 9-bit byte number 
and bit offset within the byte. Conversion from the description given 
in the EIS operand descriptor is done automatically by the hardware. 
The appending unit maintains compatibility with the earlier generation 
Multics processor by handling all unaligned data items with a bit 
offset from the prior word boundary; again with any necessary conversion 
done automatically by the hardware. Thus, a pointer register, PR^, 
may be loaded from an ITS pointer pair having a pure bit offset and 
modified by one of the EIS address register instructions (a4bd, s9bd, 
etc.) using character displacement counts. The automatic conversion 
performed ensures that the pointer register, PRi., and its matching 
address register, AR_i, both describe the same physical bit in main 
memory. 

SPECIAL NOTICE: The decimal unit has built-in hardware checks for illegal bit 
offset values but the appending unit does not except for a single 
case for packed pointers. See NOTES for Load Packed Pointers 
(lprpn) in Section 4. 
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PROCEDURE POINTER REGISTER (PPR) 



Format: - 37 bits 



Shown as part of word of control unit data 




-Other control unit data > 



Shown as part of word 4 of control unit data 



IC 



IS 



< Other control unit data- 



Figure 3-13. Procedure Pointer Register (PPR) Format 



Description : 



A combination of physical registers from the appending unit and the control 
unit. PPR.PRR, PPR.PSR, and PPR.P are located in the appending unit and 
PRR.IC is located in the control unit. The PPR is not explicitly addressable 
but its data is extracted and stored as part of the data stored with the 
Store Control Unit (scu) and Store Control Double (stcd) instructions. It 
is loaded from the control unit data with the Restore Control Unit (rcu) 
instruction. 



Function: 



The Procedure Pointer Register holds information relative to the location 
in main memory of the procedure segment in execution and the location of 
the current instruction within that segment. The functions of the individual 
constituent registers are: 



Register 
PPR.PRR 

PPR.PSR 
PPR.P 



Function 

The number of the ring in which the process is executing. 
It is set to the effective ring number of the procedure 
segment when control is transferred to the procedure. 

The segment number of the procedure being executed. 

A flag controlling execution of privileged instructions. 
Its value is 1 (permitting execution of privileged 
instructions) if PPR.PRR is and the privileged bit in 
the segment descriptor word (SDW.P) for the procedure 
is 1; otherwise, its value is 1. 



'82 



3-TJ 



AL39B 



PPR.IC 



The word offset from the origin of the procedure segment 
to the current instruction. 



TEMPORARY POINTER REGISTER (TPR) 



Format: - 42 bits 



Shown as part of word 2 of control unit dati 




Other control unit data > 



Shown as part of word 3 of control unit data 



< Other control unit data- 




Shown as part of word 5 of control unit data 




Other control unit data > 



Figure 3-14. Temporary Pointer Register (TPR) Format 



Description : 



A combination of physical registers from the appending unit and the control 
unit. TPR.TRR, TPR.TSR, and TPR.TBR are located in the appending unit and 
TPR.CA is located in the control unit. The TPR is not explicitly addressable 
but its data is extracted and stored as part of the data stored with the 
Store Control Unit (scu) instruction. It is loaded from the control unit 
data with the Restore Control Unit (rcu) instruction. 



Function: 



The temporary pointer register holds the current virtual address used by 
the processor in performing address preparation for operands, indirect words, 
and instructions. At the completion of address preparation, the contents 
of the TPR is presented to the appending unit associative memories for 



2/82 



3-15 



AL39B 



translation into the 24-bit absolute main memory address. The functions of 
the individual constituent registers are: 



Register 
TPR.TRR 
TPR.TSR 
TPR.TBR 

TPR.CA 



Function 

The current effective ring number (see Section 8). 

The current effective segment number (see Section 8). 

The current bit offset as calculated from ITS and TTP 
pointer pairs. (See Section 8.) 

The current computed address relative to the origin of 
the segment whose segment number is in TPR.TSR. (See 
Section 8.) 



DESCRIPTOR SEGMENT BASE REGISTER (DSBR) 



Format: - 51 bits 



Even word of Y-pair as stored by Store Descriptor Base Register (sdbr) 









2 
3 


2 3 

4 5 


ADDR 


000000000000 






24 


12 



Odd word of Y-pair as stored by Store Descriptor Base Register (sdbr) 



3 
6 


3 
7 




5 



5 5 
1 4 


5 


5 5 

6 9 


6 





7 
1 





BND 





U 





STACK 


1 






14 


4 


1 


4 






ra. 



Figure 3-15. Descriptor Segment Base Register (DSBR) Format 



Description : 



A physical register in the appending unit. 
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Function: 



The Descriptor Segment Base Register contains information concerning the 
descriptor segment being used by the processor. The descriptor segment 
holds the segment descriptor words (SDWs) for all segments accessible by 
the processor, that is, the currently defined virtual address space. The 
functions of its individual constituent registers are: 

Register Function 

DSBR.ADDR If DSBR.U = 1, the 24-bit absolute main memory address 
of the origin of the current descriptor segment ; otherwise, 
the 24-bit absolute main memory address, of the page 
table for the current descriptor segment. 

DSBR.BND The 14 most significant bits of the highest Y-blockl6 
address of the descriptor segment that can be addressed 
without causing an access violation, out of segment bounds, 
fault. 



DSBR.U 



DSBR. STACK 



A flag specifying whether the descriptor segment is unpaged 
(U = 1) or paged (U = 0). 

The upper 12 bits of the 15-bit stack base segment number. 
It is used only during the execution of the call6 
instruction. (See Section 8 for a discussion of generation 
of the stack segment number. ) 
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I SEGMENT DESCRIPTOR WORD ASSOCIATIVE MEMORY (SDWAH) - DPS/L68 and DPS 8M 



Format ; - 88 bits each 

Even word of Y-pairs as stored by Store Segment Descriptor Registers (ssdr) 









2 
3 


2 2 
4 6 


2 2 

7 q 


3 3 
o 2 


3 3 
3. ■? 


ADDR 


R1 


R2 


R3 









24 


3 


3 


3 


3 



Odd word of Y-pairs as stored by Store Segment Descriptor Registers (ssdr) 



3 
6 


3 
7 




5 



5 
1 


5 

2 


5 

3 


5 
4 


5 


5 
6 


5 

7 


5 

9 




7 

1 





BOUND 


R 


E 


w 


P 


U 


G 


c 


CL 


1 






14 


1 


1 


1 


1 


1 


1 


1 






14 



Data as stored by Store Segment Descriptor Pointers (ssdp) 









1 
4 


1 2 
R 6 


2 

7 


2 2 
? 9 


3 3 
9 ! 


3 3 
2 ■? 


POINTER 


000000000000 


F 








USE L68 


USE DPS 8M 



15 



12 1 2 



Figure 3-16. Segment Descriptor Word Associative Memory (SDWAM) Format 

DPS/L68 and DPS 8M 



Description ; 



A combination of 16 registers and flags from the appending unit constitute 
the Segment Descriptor Word Associative Memory (SDWAM). The registers are 
numbered consecutively from through 15 but are not explicitly addressable 
by number. 

For the DPS 8M processors, the SDW associative memory will hold the 16 most 
recently used (MRU) SDWs and have a full associative organization with 
least recently used (LRU) replacement. 

For the DPS 8M processor, the SDW associative memory will hold the 64 MRU 
SDWs and have a 4-way set associative organization with LRU replacement. 



Function: 



Hardware segmentation in the Multics processor is implemented by the appending 
unit (see Section 5 for details). In order to permit addressing by segment 
num'jer and offset as prepared in the temporary pointer register (described 



i2 
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earlier), a table containing the location and status of each accessible 
segment must be kept. This table is the descriptor segment. The descriptor 
segment is located by information held in the descriptor segment base register 
(DSBR) described earlier. 

Every time an effective segment number (TPR.TSR) is prepared, it is used as 
an index into the descriptor segment to retrieve the segment descriptor 
word (SDW) for the target segment. To reduce the number of main memory 
references required for segment addressing, the SDWAM provides a content 
addressable memory to hold the sixteen most recently referenced SDWs. 



Wheneve 
segment 
registe 
a hit, 
registe 
set to 
address 
a hit, 
loaded 
counts 
from 
prepara 



r a reference to the SDW for a segment is required, the effective 

number (TPR.TSR) is matched associatively against all 16 SDWAM. POINTER 
rs (described below). If the SDWAM match logic circuitry indicates 

all usage counts (SDWAM. USE) greater than the usage count of the 

r hit are decremented by one, the usage count of the register hit is 

15, and the contents of the register hit are read out into the 

preparation circuitry. If the SDWAM match logic does not indicate 

the SDW is fetched from the descriptor segment in main memory and 
into the SDWAM register with usage count (the oldest), all usage 
are decremented by one with the newly loaded register rolling over 

to 15, and the newly loaded register is read out into the address 
tion circuitry. Faulted SDWs are not loaded into the SDWAM. 



The functions of the constituent registers and flags of each SDWAM register 
areas follows: 

Register Function 

SDWAM. ADDR The 21-bit absolute main memory address of the page 
table for the target segment if SDWAM. U = 0; otherwise, 
the 24-bit absolute main memory address of the origin 
of the target segment. 

SDWAM. R1 Upper limit of read/write ring bracket (see Section 8). 

SDWAM. R2 Upper limit of read/execute ring bracket (see Section 
8). 



SDWAM.R3 
SDW AM. BOUND 

SDWAM. R 
SDWAM. E 

SDWAM. W 
SDWAM. P 



Upper limit of call ring bracket (see Section 8). 

The 14 high-order bits of the last Y-blockl6 address 
within the segment that can be referenced without an 
access violation, out of segment bound, fault. 

Read permission bit. If this bit is set ON, read access 
requests are allowed. 

Execute permission bit. If this bit is set ON, the SDW 
may be loaded into the procedure pointer register (PPR) 
and instructions fetched from the segment for execution. 



Write permission bit. If this 
access requests are allowed. 



bit is set ON, write 



Privileged flag bit. If this bit is set ON, privileged 
instructions from the segment may be executed if PPR.PRR 
is 0. 



SDWAM. U 



Unpaged flag bit. If this bit is set ON, the segment 
is unpaged and SDWAM. ADDR is the 24-bit absolute main 
memory address of the origin of the segment. If this 
bit is set OFF, the segment is paged and SDWAM. ADDR is 
the 24-bit absolute main memory address of the page 
table for the segment. 
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Register 



Function 



SDWAM.G 

SDWAM.C 

SDWAM.CL 

SDWAM. POINTER 
SDWAM.F 

SDWAM. USE 



Gate control bit. If this bit is set OFF, calls and 
transfers into the segment must be to an offset no greater 
than the value of SDWAM.CL as described below. 

Cache control bit. If this bit is set ON, data and/or 
instructions from the segment may be placed in the cache 
memory. 

Call limiter (entry bound) value. If SDWAM.G is set 
OFF, transfers of control into the segment must be to 
segment addresses no greater than this value. 

The effective segment number used to fetch this SDW 
from main memory. 

Full/empty bit. If this bit is set ON, the SDW in the 
register is valid. If this bit is set OFF, a hit is 
not possible. All SDWAM.F bits are set OFF by the 
instructions that clear the SDWAM. 

Usage count for the register. The SDWAM. USE field is 
used to maintain a strict FIFO queue order among the 
SDWs. When an SDW is matched, its USE value is set to 
15 (newest) on the DPS/L68 and to 63 on the DPS 8m, and 
the queue is reordered. SDWs newly fetched from main 
memory replace the SDW with USE value (oldest) and 
the queue is reordered. 



| PAGE TABLE WORD ASSOCIATIVE MEMORY (PTWAM) - DPS/L68 and DPS 8M 



Format: - 51 bits each 



Data as stored by Store Page Table Registers (sptr) 









1 
7 


1 2 
8 8 


2 

9 


3 3 
5 


ADDR 


00000000000 


M 









18 


11 


1 


6 



Data as stored by Store Page Table Pointers (sptp) 









1 
4 


1 
5 




2 
6 


2 

7 


2 2 

8 9 


3 3 
1 


3 3 
2 5 


POINTER 


PAGENO 


F 








USE L68 


USE DPS 8M 






15 






12 


1 


2 


; 


I H 



Figure 3-17. Page Table Word Associative Memory (PTWAM) Format 

DPS/L68 and DPS 8M 
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Description : 



A combination of 16 registers and flags from the appending unit constitute 
the Page Table Word Associative Memory (PTWAM). The registers are numbered 
consecutively from through 15 but are not explicitly addressable by number. 

For the DPS 8M processors, the PTW associative memory will hold the 16 most 
recently used (MRU) PTWs and have a full associative organization with 
least recently used (LRU) replacement. 

For the DPS 8M processors, the PTW associative memory will hold the 64 MRU 
PTWs and have a 4-way set associative organization with LRU replacement. 



Function: 



Hardware paging in the Multics processor is implemented by the appending 
unit (see Section 5 for details). In order to permit segment addressing by 
page number and page offset as derived from the computed address prepared 
in the temporary pointer register (TPR.CA described above), a table containing 
the location and status of each page of an accessible segment must be kept. 
This table is the page table for the segment. The page table for an accessible 
paged segment is located by information held in the segment descriptor word 
(SDW) for the segment. 

Every time a computed address (TPR.CA) for a paged segment is prepared, it 
is separated into a page number and a page offset. The page number is used 
as an index into the page table to retrieve the page table word (PTW) for 
the target page. To reduce the number of main memory references required 
for paging, tne PTWAM provides a content addressable memory to hold the 16 
most recently referenced PTWs. 

Whenever a reference to the PTW for a page of a paged segment Is required, 
the page number (as derived from TPR.CA) is matched associativeiy against 
all 16 PTWAM. PAGENO registers (described below) and, simultaneously, TPR.TSR 
is matched against PTWAM. POINTER (described below). If the PTWAM match 
logic circuitry indicates a hit, all usage counts (PTWAM. USE) greater than 
the usage count of the register hit are decremented by one, the usage count 
of the register hit is set to 15, and the contents of the register hit are 
read out into the address preparation circuitry. If the PTWAM match logic 
does not indicate a hit, the PTW is fetched from main memory and loaded 
into the PTWAM register with usage count (the oldest), all usage counts 
are decremented by one with the newly loaded register rolling over from 
to 15, and the newly loaded register is read out into the address preparation 
circuitry. Faulted PTWs are not loaded into the PTWAM. 



2/82 3-21 AL39B 



The functions of the constituent registers and flags of each PTWAM register 
are: (See Section 8 for additional details.) 



Register 
PTWAM. ADDR 



PTWAM. M 



PTWAM. POINTER 
PTWAM. PAGENO 



PTWAM. F 



PTWAM. USE 



Function 

The 18 high-order bits of the 24-bit absolute main memory 
address of the page. The hardware ignores low-order 
bits of this page address according to page size based 
on the following: 



Page size 


ADDR bits 


in words 


ignored 


64 


none 


128 


17 


256 


16-17 


512 


15-17 


1024 


14-17 


2048 


13-17 


4096 


12-17 



Page modified flag bit. This bit is set ON whenever 
the PTW is used for a store type instruction. When the 
bit changes value from to 1, a special extra cycle is 
generated to write it back into the PTW in the page 
table in main memory. 

The effective segment number used to fetch this PTW 
from main memory. 

The 12 high-order bits of the 18-bit computed address 
(TPR.CA) used to fetch this PTW from main memory. 
Low-order bits are forced to zero by the hardware and 
not used as part of the page table index according to 
page size based on the following: 



Page size 
in words 

6T» 

128 

256 

512 

1024 

2048 

4096 



PAGENO bits 
forced 
none 
1 
10-1 
09-1 
08-1 
07-1 
06-1 



Full/empty bit. If this bit is set ON, the PTW in the 
register is valid. If this bit is set OFF, a hit is 
not possible. All PTWAM. F bits are set OFF by the 
instructions that clear the PTWAM. 

Usage count for the register. The PTWAM. USE field is 
used to maintain a strict FIFO queue order among the 
PTWs. When an PTW is matched its USE value is set to 
15 (newest) on the DPS/L68 and to 63 on the DPS 8M, and 
the queue is reordered. PTWs newly fetched from main 
memory replace the PTW with USE value (oldest) and 
the queue is reordered. 
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FAULT REGISTER (FR) - DPS/L68 



Format: 



72 bits 



Even word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 01 








1 




P 



3 




4 






6 




7 



8 




9 


1 



1 
1 


1 
2 


1 
3 


1 

4, 


1 


1 1 

6 q 


2 2 
3 


2 2 
4 7 


2 3 
8 1 


3 
2 


3 
3. 


3 
if 


3 


a 


b 


c 


d 


e 


f 


g 


h 


i 


3 


k 


1 


m 


n 








IAA 


IAB 


IAC 


IAD • 


P 


q 


r 


s 



1111111111111111 



4 1111 



Odd word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 01 



3 7 
6 1 


000000000000000000000000000000000000 



w 



Figure 3-18. Fault Register (FR) Format - DPS and L68 



Description : 



A combination of flags and registers all located in the control unit. The 
register is stored and cleared by the Store Central Processor Register 
(scpr), TAG = 01, instruction. Note that the data is stored into the word 
pair at location Y. The Fault Register cannot be loaded. 



Function: 



The Fault Register contains the conditions in the processor for several of 
the hardware faults. Data is strobed into the Fault Register during a 
fault sequence. Once a bit or field in the Fault register is set, it 
remains set until the register is stored and cleared. The data is not 
overwritten during subsequent fault events. 

The functions of the constituent flags and registers are: 



Flag or 
key register 

a ILL OP 

b ILL MOD 

c ILL SLV 

d ILL PR0C 



Function 

An illegal operation code has been detected. 

An illegal address modifier has been detected. 

An illegal BAR mode procedure has been encountered. 

An illegal procedure other than the three above has 
been encountered. 
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Flag or 
key register 



Function 



e NEM 

f 00B 

g ILL DIG 

h PROC PA.RU 

i PROC PARL 

j $CON A 

k $CON B 

1 $CON C 

m $CON D 

n DA ERR1 

o DA ERR2 





IAA 






IAB 






IAC 






IAD 




p 


CPAR 


DIR 


q 


CPAR 


STR 


r 


CPAR 


IA 



s CPAR BLK 



A nonexistent main memory address has been requested. 

A BAR mode boundary violation has occurred. 

An illegal decimal digit or sign has been detected by 
the decimal unit. 

A parity error has been detected in the upper 36 bits 
of data. 

A parity error has been detected in the lower 36 bits 
of data. 

A $CONNECT signal has been received through port A. 

A $CONNECT signal has been received through port B. 

A $CONNECT signal has been received through port C. 

A $CONNECT signal has been received through port D. 

Operation not complete. Processor/system controller 
interface sequence error 1 has been detected. 
($DATA-AVAIL received with no prior $INTERRUPT sent.) 

Operation not complete. Processor/system controller 
interface sequence error 2 has been detected. (Multiple 
$DATA-AVAIL received or $DATA-AVAIL received out of 
order. ) 

Coded illegal action, port A. (see Table 3-2) 

Coded illegal action, port B. (See Table 3-2) 

Coded illegal action, port C. (See Table 3-2) 

Coded illegal action, port D. (See Table 3-2) 

A parity error has been detected in the cache memory 
directory. 

A data parity error has been detected in the cache memory. 

An illegal action has been received from a system 
controller during a store operation with cache memory 
enabled. This implies that the data are correct in 
cache memory and incorrect in main memory. 

A cache memory parity error has occurred during a cache 
memory data block load. 
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Table 3-2. System Controller Illegal Action Codes 



Code Priority 



00 
01 
02 
03 
04 
05 
06 
07 

10 
1 1 
12 

13 
14 

15 
16 

17 



05 
01 

12 
1 1 
10 

04 
13 
03 
07 
02 

06 
08 

09 



Fault 



Command 

Store 

Command 

Command 

Parity 

Parity 

Parity 

Command 

Command 

Command 

Store 

Parity 

Parity 
Parity 

Parity 



Reason 



No illegal action 

Unassigned 

Nonexistent address 

Stop on condition 

Unassigned 

Data parity, store unit to system controller 

Data parity in store unit 

Data parity in store unit and 

store unit to system controller 



Not control 



U) 



Port not enabled 
Illegal command 
Store unit not ready 
Zone-address-command parity, 

processor to system controller 
Data parity, processor to system controller 
Zone-address-command parity, 

system controller to store unit 
Data parity, system controller to store unit 



(a) This illegal action code not relevant to later model system controllers. 



FAULT REGISTER (FR) - DPS 8M 



Format : - 72 bits 

Even word of Y-pair as stored by Store Control Processor Register (scpr), 
TAG = 01 





n 



1 










if 






6 




7 




R 




p 


1 
n 


1 

1 


1 
P 


1 
3 


1 
4 


1 
5, 


1 1 
6 Q 


2 2 

^ 


2 2 
4 7 


2 3 
8 1 


3 


3 

i 


3 
1 


3 


a 


b 


c 


d 


e 


f 


g 


h 


i 


J 


k 


1 


m 


n 


o 





IAA 


IAB 


IAC 


IAD 


p 


q 


r 


s 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


4 


4 


4 


4 


i 


i 


1 


1 



Odd word of Y-pair is stored by Store Control Processor Register (scpr), 
TAG = 01 



3333U4H444444 
6 7 8 q 1 > \1 ^ 6 7 8 



00000000000000000000000 



I 
o oj 

25 



Figure 3-19- Fault Register (FR) Format - DPS 8M 
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Function: 



The Fault Register contains the conditions in the processor for several of 
the hardware faults on the DPS 8M CPU and cache directory buffer overflows. 
Data is strobed into the Fault Register during a fault or buffer overflow 
fault sequence. Once a bit or field in the Fault Register is set, it 
remains set until the register is stored and cleared. The data is not 
overwritten during subsequent fault events. 

The functions of the constituent flags and registers are: 



Flag or 
key register Fault 

a ILL OP IPR 

b ILL MOD IPR 

c ILL SLV IPR 

d ILL PROC IPR 

e NEM ONC 
f 00B STR 
b ILL DIG IPR 

h PROC PARU PAR 

i PROC PARL PAR 



j 


$CON A 


CON 


k 


$CON B 


CON 


1 


$CON C 


CON 


tn 


$CON D 


CON 


n 


DA ERR1 


ONC 



DA ERR2 



ONC 



IAA 
IAB 
IAC 
IAD 
p CPAR DIR None 

q CPAR STR PAR 



Function 

An illegal operation code has been detected. 

An illegal address modifier has been detected. 

An illegal BAR mode procedure has been encountered. 

An illegal procedure other than the three above has 
been encountered. 

A nonexistent main memory address has been requested. 

A BAR mode boundary violation has occurred. 

An illegal decimal digit or sign has been detected by 
the decimal unit. 

A parity error has been detected in the upper 36 bits 
of data. 

A parity error has been detected in the lower 36 bits 
of data. 

A $CONNECT signal has been received through port A. 

A $CONNECT signal has been received through port B. 

A $CONNECT signal has been received through port C. 

A $CONHECT signal has been received through port D. 

Operation not complete. Processor/system controller 
interface sequence error 1 has been detected. 
($DATA-AVAIL received with no prior $INTERRUPT sent.) 

Operation not completed. Processor/system controller 
interface sequence error 2 has been detected. (Multiple 
$DATA-AVAIL received or $DATA-AVAIL received out of 
order. ) 



Coded illegal action, port A. 

Coded illegal action, port B. 

Coded illegal action, port C. 

Coded illegal action, port D. 



(See Table 3-2) 

(See Table 3-2) 

(See Table 3-2) 

(see Table 3-2) 



A parity error has been detected in the cache memory 
directory. 

A data parity error has been detected in the cache 
memory. 
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Flag or 
key register Fault Function 



r CPAR IA PAR An illegal action has been received from a system 

controller during a store operation with cache memory 
enabled. This implies that the data are correct in 
cache memory and incorrect in main memory. 

s CPAR BLK PAR A cache memory parity error has occurred during a cache 

memory data block load. 

Cache Duplicate Directory WNO Buffer Overflow 
t None Port A 

u Hone Port B 

v None Port C 

w None Port D 

x None Cache Primary Directory WNO Buffer Overflow 

y None Write Notify (WNO) Parity Error on Port A, B, C, or D. 

None Cache Duplicate Directory Parity Error 

z None Level 

A None Level 1 

B None Level 2 

C None Level 3 

D Cache Duplicate Directory Multiple Match 

E None A parity error has been detected in the SDWAM. 

F None A parity error has been detected in the PTWAM. 



MODE REGISTER (MR) - DPS and L68 



Format: - 33 bits 



Even word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 06 




0, 




1 
4 


i 


1 

6 


1 
7 


1 1 2 

§90 


2 2 2 2 2 2 2 

1 2 ? U s 6 7 


2 

8 


2 
Q 


3 
q 


3 
1 


3 3 3 
2.3. « 


3 


FFV 





a 


b 


OPCODE 


i 


3 


k 


a- 


mjo 


n 


c[dfe 


f| g | h |o o 






15 


1 


1 


1 


1V1 


1* 2* 2 2 


1 


1 


1 


1 


1 2 


1 



Figure 3-20. Mode Register (MR) Format - DPS and L68 



Description ; 



An assemblage of flags and registers from the control unit. The Mode Register 
and the Cache Mode Register are both stored into the Y-pair by the Store 
Central Processor Register (scpr), TAG = 06. The Mode Register is loaded 
with the Load Central Processor Register (lcpr), TAG = OH, instruction. 
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Function: 



The Mode Register controls the operation of those features of the processor 
that are capable of being enabled and disabled. 

The functions of the constituent flags and registers are: 

Flag or 
key register Function 

FFV A floating-fault vector address. The 15 high-order bits 

of the Y-block8 address of four word pairs constituting 
a floating-fault vector. Traps to these floating faults 
are generated by other conditions the mode register sets. 

a OC TRAP Trap on OPCODE match. If this bit is set ON and OPCODE 

matches the operation code of the instruction for which 
an address is being prepared (including indirect cycles), 
generate the second floating fault (xed FFV+2). See 
NOTE below. 

b ADR TRAP Trap on ADDRESS match. If this bit is set ON and the 

computed address (TPR.CA) matches the setting of the 
address switches on the processor maintenance panel, 
generate the fourth floating fault (xed FFV+6). See 
NOTE below. 

OPCODE The operation code on which to trap if OC TRAP (bit 16, 
key a) is set ON or for which to strobe all control 
unit cycles into the control unit history registers if 
O.C$d (bit 29, key j) is set ON. 

or 

Processor conditions codes as follows if OC TRAP (bit 
16, key a) and O.C$<* (bit 29, key j) are set OFF and 
t VOLT (bit 32, key m) is set ON. 

Key Condition 

c Set control unit overlap inhibit if set ON. The 
control unit waits for the operations unit to complete 
execution of the even instruction of the current 
instruction pair before it begins address preparation 
for the associated odd instruction. The control 
unit also waits for the operations unit to complete 
execution of the odd instruction before it fetches 
the next instruction pair. 

d Set store overlap inhibit if set ON. The control 
unit waits for completion of a current main memory 
fetch (read cycles only) before requesting a main 
memory access for another fetch. 

e Set store incorrect data parity if set ON. The 
control unit causes incorrect data parity to be 
sent to the system controller for the next store 
instruction and then resets bit 20. 

f Set store incorrect zone-address-command (ZAC) 
parity if set ON. The control unit causes incorrect 
zone-address-command (ZAC) parity to be sent to 
the system controller for each main memory cycle 
of the next store instruction and resets bit 21 at 
the end of the instruction. 



2/82 3-28 AL39B 



Flag or 
key register Function 



Key Condition 

g Set timing margins if set ON. If £ VOLT (bit 32, 
key m) is set ON and the margin control switch on 
the processor maintenance panel is in PROG position, 
set processor timing margins as follows: 



22,23 


Margin 


0,0 


normal 


0,1 


slow 


1,0 


normal 


1,1 


fast 



h Set +5 voltage margins if set ON. If £ VOLT (bit 
32, key m) is set ON and the margin control switch 
on the processor maintenance panel is in the PROG 
position, set +5 voltage margins as follows: 



24,25 


Margin 


0,0 


normal 


0,1 


low 


1,0 


high 


1,1 


normal 



i Trap on control unit history register count overflow if 

set ON. If this bit and STROBE £ (bit 30, key k) are 
set ON and the control unit history register counter 
overflows, generate the third floating fault 
(xed FFV+4). Further, if FAULT RESET (bit 31, key 1) 
is set, reset STROBE £ (bit 30, key k) , locking the 
history registers. A Load Central Processor Register 
(lcpr), TAG = 04, instruction setting bit 28 ON resets 
the control unit history register counter to zero. (See 
NOTE below.) 

j 0.C$d Strobe control unit history registers on OPCODE match. 

If this bit and STROBE 6 (bit 30, key k) are set ON and 
the operation code of the current instruction matches 
OPCODE, strobe the control unit history registers on 
all control unit cycles (including indirect cycles). 

k STROBE £ Enable history registers. If this bit is set ON, all 

history registers are strobed at appropriate points in 
the various processor cycles. If this bit is set OFF 
or MR ENABLE (bit 35, key n) is set OFF, all history 
registers are locked. This bit is set OFF with a Load 
Central Processor Register (lcpr), TAG = 04, instruction 
providing a bit, by an operation not complete fault, 
and, conditionally, by other faults (see FAULT RESET 
(bit 31, key 1) below). Once set OFF, this bit must be 
be set ON with a Load Central Processor Register (lcpr), 
TAG = 04, instruction providing a 1 bit to re-enable 
the history registers. 

1 FAULT RESET History register lock control. If this bit is set ON, 

set STROBE £ (bit 30, key k) OFF, locking the history 
registers for all faults including the floating faults. 
See NOTE below. 

m £ VOLT Test mode indicator. This bit is set ON whenever the 

TEST/NORMAL switch on the processor maintenance panel 
is in TEST position; otherwise, it is set OFF. It serves 
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Flag or 
key register 



Function 



n MR ENABLE 



to enable the program control of voltage and timing 
margins. 

Enable mode register. When this bit is set OK, all 
other bits and controls of the mode register are active. 
When this bit is set OFF, the mode register controls 
are disabled. 



NOTE: The traps described above (address match, OPCODE match, control unit 
history register counter overflow) occur after completion of the next 
odd instruction following their detection. They are handled as Group 
7 faults in regard to servicing and inhibition. (See Section 7 for 
descriptions of these faults.) The complete Group 7 priority sequence 
(in increasing order) is: 

1 - Connect 

2 - Time runout 

3 - Shutdown 

4 - OPCODE trap 

5 - Control unit history register counter overflow 

6 - Address match trap 

7 - External interrupts 



MODE REGISTER (MR) - DPS 8M 



Format : - 36 bits 

Even word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 06 



1 
7 


1 

8 


1 

9 


2 




2 

1 


2 2 

2 3, 


2 2 

,±_i 


2 2 
6 T 


2 

8 


2 

.2- 


3 



3 

1 


3 
2 


3 
3 


3 
4 


3 


000000000000000000 


a 


b 





d 


e 


f 





g 


h 


i 


J 


k 


i 





m 


18 


1 


1 


1 


1 


2 


2 


2 


1 


1 


1 


1 


1 


1 


1 


1 



Figure 3-21. Mode Register (MR) Format - DPS 8M 



Description : 



An assemblage of flags and registers from the control unit. The Mode Register 
and the Cache Mode Register are both stored into the Y-pair by the Store 
Central Processor Register (scpr), TAG = 06. The Mode Register is loaded 
with the Load Central Processor Register (lcpr), TAG = 04, instruction. 



Function: 



The mode register controls the operation of those features of the processor 
that are capable of being enabled and disabled. 
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The functions of the constituent flags and registers are: 

Flag or 
key register Function 

a cuolin Set CU overlap inhibit. The CU waits for the OU to 

complete execution of the even instruction before it 
begins address preparation for the associated odd 
instruction. The CU also waits for the OU to complete 
execution of the odd instruction before it fetches the 
next instruction pair. 

b solin Set store overlap inhibit. The CU waits for completion 

of a current memory fetch (read cycles only) before 
requesting a memory access for another fetch. 

C sdpap Set store incorrect data parity. The CU causes incorrect 

data parity to be sent to the SC for the next data 
store instruction and then resets bit 20. 

d separ Set store incorrect ZAC parity. The CU causes incorrect 

zone-address-command (ZAC) parity to be sent to the SC 
for each memory cycle of the next data store instruction 
and resets bit 21 at the end of the instruction. 

e tm Set timing margins. If bit 32 key (K) is set and the 

margin control switch on the CPU maintenance panel is 
in program position, set CPU timing margins as follows: 



22,23 


margin 


0,0 


normal 


0,1 


slow 


1,0 


normal 


1,1 


fast 



f vm Set +5 voltage margins. If bit 32 (key K) is set and 

the margin control switch on the CPU maintenance panel 
is in the program position, set +5 voltage margins as 
follows: 

24,25 margin 

0,0 normal 

0,1 low 

1.0 high 

1 . 1 normal 

g hrhlt Stop HR Strobe on HR Counter Overflow. (Setting bit 28 

shall cause the HR counter to be reset to zero.) 

h hrxfr Strobe the HR on Transfer Made. If bits 29,30, and 35 

are = 1, the HR will be strobed on all Transfers Made. 
Bits 36-53 of the OU/DU register will indicate the "From*' 
location and bits 36-59 of the CU register will contain 
the real address of the final "To" location. 

i ihr Enable History Registers. If bit 30 = 1 , the HRs may 

be strobed. If bit 30 = or bit 35 = 0, they will be 
locked out. This bit will be reset by either an LCPR 
with the bit corresponding to 30 = or by an Op Not 
Complete fault. It may be reset by other faults (see 
bit 3D. After being reset, it must be enabled by another 
LCPR instruction before the History Registers may be 
strobed again. 
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Flag or 
key register 



Function 



j ihrrs 



k mrgctl 



1 hexfp 



m emr 



Additional resetting of bit 30. If bit 3T = 1, the 
following faults also reset bit 30: 

- Lock Op 

- Parity 

- Command 

- Store 

- Illegal Procedure 

- Shutdown 

Margin Control. Bit 32 informs the software when it 
can control margins. A one indicates that software has 
control. When the LOCAL/REMOTE switch on the power supply 
is in REMOTE and bit 35 = 1 , bit 32 is set to 1 by 
occurrence of the following conditions: the NORMAL/TEST 
switch is in the TEST position, the Memory and CU Overlap 
Inhibit switches are OFF, the Timing Margins for the 
OU, CU, DU and VU are NORMAL, and the Forced Data and 
ZAC Parity are OFF. 

Hexadecimal Exponent Floating Point Arithmetic Mode can 
be set. When this bit is set, the Hex mode becomes 
effective when the Indicator Register bit 32 is set to 
1. 

Enable Mode Register. Unless bit 35 = 1, all other bits 
in the Mode Register are ignored and the History Register 
is ignored and locked. 



| CACHE MODE REGISTER (CMR) - DPS and L68 



Format: - 28 bits 



Odd word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 06 



555555555566666 
1 . 2 A 4 A 6 . 7 . 8 . q .°. 1 . ? V* 



6 7 7 

1L1 



CACHE DIR ADDRESS 







15 1 1 1 1 1 1 1 1 1 1 1 



T 



Figure 3-22. Cache Mode Register (CMR) Format - DPS and L68 



Description : 



An assemblage of flags and registers from the control unit. The Mode Register 
and Cache Mode Register are both stored into the Y-pair by the Store Central 
Processor Register (scpr), TAG = 06, instruction. The Cache Mode Register 
is loaded with the Load Central Processor Register (lcpr), TAG = 02, 
instruction. 
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The data stored from the cache mode register is address-dependent. The 
algorithm used to map main memory into the cache memory (see Section 9) is 
effective for the Store Central Processor Register (scpr) instruction. In 
general, the user may read out data from the directory entry for any cache 
memory block by proper selection of certain subfields in the 24-bit absolute 
main memory address. In particular, the user may read out the directory 
entry for the cache memory block involved in a suspected cache memory error 
by ensuring that the required 24-bit absolute main memory address subfields 
are the same as those for the access which produced the suspected error. 

The fault handling procedure(s) should be unencacheable (SDW.C = 0) and the 
history registers and cache memory should be disabled as quickly as possible 
in order that vital information concerning the suspected error not be lost. 



Function: 



The Cache Mode register provides configuration information and software 
control over the operation of the cache memory. Those items with an "x" in 
the column headed L are not loaded by the Load Central Processor Register 
(lcpr), TAG = 02, instruction. 

The functions of the constituent flags and registers are: 



key L Register 

x CACHE DIR 
ADDRESS 

a x PAR BIT 

b x LEV FOL 



c 


CSH1 ON 


d 


CSH2 ON 


e 


OPND ON 


f 


INST ON 


g 


CSH REG 



h x STR ASD 

i x COL FUL 

j x RRO A,B 

k LUF MSB.LSB 



Function 

15 high-order bits of the cache memory block address 
from the cache directory. 

Cache memory directory parity bit. 

The selected column and level is loaded with active 
data. 

Enable the upper 1024 words of the cache memory (see 
Section 9). 

Enable the lower 1024 words of the cache memory (see 
Section 9). 

Enable the cache memory for operands (see Section 9). 

Enable the cache memory for instructions (see Section 
9). 

Enable cache-to-register (dump) mode. When this bit is 
set ON, double-precision operations unit read operands 
(e.g., Load AQ (ldaq) operands) are read from the cache 
memory according to the mapping algorithm and without 
regard to matching of the full 24-bit absolute main 
memory address. All other operands address main memory 
as though the cache memory were disabled. This bit is 
reset automatically by the hardware for any fault or 
interrupt. 

Enable store aside. When this bit is set ON, the processor 
does not wait for main memory cycle completion after a 
store operation but proceeds after the cache memory cycle 
is complete. 

Selected cache memory column is full. 

Cache round robin counter (see Section 9). 

Lockup timer setting. The lockup timer may set to four 
different values according to the value of this field. 
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key L Register 



Function 



LOT 
value 


1 
2 
3 



Lockup 
time 

2ms 

Urns 

8ms 

16ms 



The lockup timer is set to 16ms when the processor is 
initialized. 



CACHE MODE REGISTER (CMR) - DPS 8M 



Format: 



36 bits 



Odd word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 06. 



555555555566666 66677 
nni|56 7 8 9.0.1.2 3 H 7 8 9 1 



CACHE DIR ADDRESS 







15 1 1 1 1 1 1 1 1 1 1 1 



4 1 1 



Figure 3-23. Cache Mode Register (CMR) Format - DPS 8M 



Description : 



An assemblage of flags and registers from the control unit. The Mode Register 
and Cache Mode Register are both stored into the Y-pair by the Store Central 
Processor Register (scpr), TAG = 06, instruction. The Cache Mode Register 
is loaded with the Load Central Processor Register (lcpr), TAG = Od, 
instruction. 

The data stored from the Cache Mode register is address-dependent. The 
algorithm used to map main memory into the cache memory (see Section 9) is 
effective for the Store central Processor Register (scpr) instruction. In 
general, the user may read out data from the directory entry for any cache 
memory block by proper selection of certain subfields in the 24-bit absolute 
train memory address. In particular, the user may read out the directory 
entry for the cache Memory block involved in a suspected cache memory error 
by ensuring that the required 24-bit absolute main memory address subfields 
are the same as those for the access which produced the suspected error. 

The fault handling procedure(s) should be unencacheable (SDW.D = 0) and the 
history registers and cache memory should be disabled as quickly as possible 
in order that vital information concerning the suspected error not be lost. 
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Function: 



The Cache Mode Register provides configuration information and software 
control over the operation of the cache memory. Those items with an "x" in 
the column headed L are not loaded by the Load Central Processor Register 
(lcpr), TAG = 02, instruction. 

The functions of the constituent flags and registers are: 



key L Register 

x CACHE DIR 
ADDRESS 

a x PAR BIT 

b x LEV FUL 

c CSH1 ON 

d CSH2 ON 

e INST ON 

f CSH REG 



g x STR ASD 

h X COL FUL 

i x RRO A,B 
J 

k LUF MSB.LSB 



Function 

15 high-order bits of the cache memory block address 
from the cache directory. 

Cache memory directory parity bit. 

The selected column and level is loaded with active 
data. 

Enable the upper 4096 words of the cache memory (see 
Section 9). 

Enable the lower 4096 words of the cache memory (see 
Section 9). 

Enable the cache memory for instructions (see Section 
9). 

Enable cache-to-register (dump) mode. When this bit is 
set ON, double-precision operations unit read operands 
(e.g., Load AQ (ldaq) operands) are read from the cache 
memory according to the mapping algorithm and without 
regard to matching of the full 24-bit absolute main 
memory address. All other operands address main memory 
as though the cache memory were disabled. This bit is 
reset automatically by the hardware for any fault or 
interrupt. 

Enable store aside. When this bit is set ON, the processor 
does not wait for main memory cycle completion after a 
store operation but proceeds after the cache memory cycle 
is complete. 

Selected cache memory column is full. 

Cache round-robin counter (see Section 9). 

Bypass cache bit. Enables the bypass option of SDW.C 
when set OFF. See Notes below for further information. 

Lockup timer setting. The lockup timer may set to four 
different values according to the value of this field. 



LUF 
value 



1 
2 
3 



Lockup 
time 

2ms 

4ms 

8ms 

16ms 



The lockup timer is set to 16ms when the processor is 
initialized. 
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Notes 



The COL FUL, RRO A, RRO B, and CACHE DIR ADDRESS fields reflect different 
locations in cache depending on the final (absolute) address of the 
scpr instruction storing this data. 

If either cache enable bit c or d changes from disable state to enable 
state, the entire cache is cleared. 

The DPS 8M processors contain an 8k hardware-controlled cache memory. 
When running a mixed configuration of DPS 8M and DPS/L68 processors, 
bit 68 of the cmr (reference j) allows the DPS 8M processor to utilize 
software compatible with the older 2k software controlled by the DPS/L68 
and DPS processors. The following summarizes the operation of the DPS 
8M hardware-controlled cache. 

a. The cache bypass option in the segment descriptor word is retained. 
An overriding bypass enable, bit 68 of the Cache Mode Register, 
is added. The cache mode is set as follows: 



SDW.C 


CMR 68 


RESULTANT 
CACHE MODE 


Use Cache 


X 


Use Cache 


Bypass Cache 


Bypass Cache 


Bypass Cache 


Bypass Cache 


Use Cache 


Use Cache 



b. All close gate instructions, LDAC, LDQC , STAC, STACQ, and SZNC 
automatically bypass cache. Two features are added to ensure 
integrity of gated shared data; one is added during the close 
gate operation and the other during the open gate operation. The 
instruction following the close gate instruction bypasses cache 
if the instruction is a Read or a Read-alter-rewrite . The open 
gate operation must be performed with either a STC2 or STACQ, 
which includes the synchronizing function. The synchronizing 
function forces the processor to delay the open gate operation 
until it is notified by the SCU that write completes have occurred 
and write notifications requesting cache block clears have been 
sent to the other processors for all write instructions that the 
processor previously issued. 

c. Read-alter-rewrite instructions no longer automatically bypass 
cache. Cache behavior for these instructions is determined fully 
by SDW.C. If the bypass cache mode is set, these instructions 
bypass cache and issue read-lock-write-unlock commands to memory. 
If a cache directory match occurs, the location is cleared. 

d. All accesses to memory by SDW and PTW associative memory hardware 
continue to bypass cache. Operations are Reads for SDWs, 
Read-alter-rewrites with lock for PTWs and setting the page Used 
bit, and Writes for setting the page Modified and Used bits. For 
Writes, the hardware also disables the key line so that the SCU 
lock is honored. This is consistent with dynamic PTW modification 
by software, which also bypasses cache and uses Read-alter-rewrite 
instructions. 



The instructions that cleared the associative memories and also 
cleared cache or selective portions of cache are changed to eliminate 
the cache clear function. Bit C (TPR.CA) 1t -, is ignored. These 
instructions also include disable/enable 
half of the associative memories. 



capabilities for each 
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f. Cache mode register bit 56, which had previously controlled cache 
bypass for operands, is disregarded. All other cache control 
bits are continued. However, maintenance panel cache control 
function is restricted to cache half enable/disable functions. 



CONTROL UNIT (CU) HISTORY REGISTERS - DPS and L68 

The L68 and DPS processors have four sets of 16 history requests. There is 
one set for each major unit: the Control Unit, CU; the Operations Unit, OU; the 
Decimal Unit, DU; and the Appending Unit, APU. The DPS 8M Processor has four 
sets of 64 history registers. There is one set for the CU, two sets for the 
APU, and one set that combines the history of the OU and DU. 

Because the history registers for the L68 and DPS and the DPS 8M are different 
in number and content, they are described separately. The following section 
describes the L68 and DPS history registers first, followed by a description of 
the DPS 8M history registers. 



Format: 



72 bits each 



Even word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 20 




Q 




1 




p 




JL 







JL 



6 






8 




9 


i 
o 


1 
1 


1 
2 


1 
3, 


1 


1 

"7 


1 
6 


1 
7 


1 
8 




2 
8 


2 

9 


3 





3 
"5 


a 


b 


c 


d 


e 


f 


g 


h 


i 


J 


k 


1 


m 


n 





P 


q 


r 


OPCODE 


I 


p 


TAG 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 




10 


1 


1 






6 



Odd word of Y-pair as stored by Store Central Processor Register (scpr). 
TAG = 20 of, 



ADDRESS 



5 5 

JU- 



TS^ 



CMD 



5 5 

il 



6 6 

21 



SEL 



6 7 7 
".0.1 



4 111111111 



Figure 3-24. Control Unit (CU) History Register Format - DPS and L68 



Description : 



A combination of 16 flags and registers from the control unit. The 16 
registers are handled as a rotating queue controlled by the Control Unit 
History Register counter. The counter is always set to the number of the 
oldest entry and advances by one for each history register reference (data 
entry or Store Central Processor Register (scpr) instruction). Multicycle 
instructions (such as Load Pointer Registers from ITS Pairs (lpri), Load 
Registers (lreg), Restore Control Unit (rcu), etc.) have an entry for each 
of their cycles. 
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Function : 

A control unit history register entry shows the conditions at the end of 
the control unit cycle to which it applies. The 16 registers hold the 

conditions for the last 16 control unit cycles. Entries are made according 
to controls set in the Mode Register. (See Mode Register earlier in this 
section. ) 

The meanings of the constituent flags and registers are: 

key Flag Name Meaning 

a PIA Prepare instruction address 

b POA Prepare operand address 

c RIW Request indirect word 

d SIW Restore indirect word 

e POT Prepare operand tally (indirect tally chain) 

f PON Prepare operand no tally (as for POT except no chain) 

g RAW Request read-alter-rewrite word 

h SAW Restore read-alter-rewrite word 

i TRGO Transfer GO (conditions met) 

j XDE Execute even instruction from Execute Double (xed) pair 

k XDO Execute odd instruction from Execute Double (xed) pair 

1 IC Execute odd instruction of the current pair 

m RPTS Execute a repeat instruction 

n WI Wait for instruction fetch 

o AR F/E 1 = ADDRESS has valid data 

p XIP NOT prepare interrupt address 

q FLT NOT prepare fault address 

r BASE NOT BAR mode 

OPCODE Operation code from current instruction word 

I Interrupt inhibit bit from current instruction word 

P Pointer register flag bit from current instruction word 

TAG Current address modifier. This modifier is replaced 
by the contents of the TAG fields of indirect words 
as they are fetched during indirect chains. 

ADDRESS Current computed address (TPR.CA) 

CMD System controller command 

SEL Port select bits. (Valid only if port A-D is selected) 

s XEC-INT An interrupt is present 

t INS-FETCH Perform an instruction fetch 
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key Flag Name 



Meaning 



u CO-STORE 

v OU-STORE 

w CU-LOAD 

x OU-LOAD 

y DIRECT 



z PC-BUSY 
* BUSY 



Control unit store cycle 
Operations unit store cycle 
Control unit load cycle 
Operations unit load cycle 
Direct cycle 

Port control logic not busy 
Port interface busy 



CONTROL UNIT (CU) HISTORY REGISTERS - DPS 8M 



Format: - 72 bits each 



Even word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 20 









1 



2 




3, 



4 






6 




7 



8 




9 


1 




1 
1 


1 
2 


1 
3. 


1 
4 


1 


1 
6 


1 

7 


1 
8 






2 
8 


2 

9 


3 





3 
5 


a 


b 


c 


d 


e 


f 


g 


h 


i 


j 


k 


1 


m 


n 





P 


q 


r 


OPCODE 


I 


p 


TAG 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 






10 


1 


1 






6 



Odd word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 20 



2 
3 


2 2 
4 8 


2 

9 


3 


3 
1 


3 
2 


3 
3. 


3 
4 


3 


ADDRESS 


CMD 


s 


t 


u 


V 


w 


X 






24 



5 1111111 



Figure 3-25. Control Unit (CU) History Register Format - DPS 8m 



Description : 



A combination of 64 flags and registers from the control unit. The 64 
registers are handled as a rotating queue, controlled by the control unit 
history register counter, in which only the 16 most recently used are stored 
(except in the event of a system crash in which case all 64 will be saved). 
The counter is always set to the number of the oldest entry and advances by 
one for each history register reference (data entry or Store Central Processor 
Register (scpr) instruction). Multicycle instructions (such as Load Pointer 
Registers from ITS Pairs (lpri), Load Registers (lreg), Restore Control 
Unit (rcu), etc) have an entry for each of their cycles. 
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Function: 



A control unit history register entry shows the conditions at the end of 
the control unit cycle to which it applies. The 16 registers hold the 
conditions for the last 16 control unit cycles. Entries are made according 
to controls set in the Mode Register. (See Mode Register earlier in this 
section- ) 

The meanings of the constituent flags and registers are: 



key 


Flag Name 


a 


PIA 


b 


POA 


c 


RIW 


d 


SIW 


e 


POT 


f 


PON 


g 


RAW 


h 


SAW 


i 


RTRGO 


J 


XDE 


k 


XDO 


1 


IC 


m 


RPTS 


n 


PORTF 





INTERNAL 


P 


PA I 


q 


PFA 


r 


PRIV 




OPCODE 




I 




P 




TAG 




ADDRESS 




CMD 


s 


XINT 


t 


IFT 


u 


CRD 


V 


MRD 



Meaning 

Prepare instruction address 

Prepare operand address 

Request indirect word 

Restore indirect word 

Prepare operand tally 

Prepare operand no tally 

Request read-alter-rewrite word 

Restore read-alter-rewrite word 

Remember transfer GO (condition met) 

XED from even location 

XED from odd location 

Even/odd instruction pair 

Repeat operation 

Memory cycle to port on previous cycle 

Memory cycle to cache or direct on previous cycle 

Prepare interrupt address 

Prepare fault address 

In privileged mode 

Opcode of instruction 

Inhibit interrupt bit 

AR reg mod flag 

Tag field of instruction 

Absolute mean address of instruction 

Processor command register 

Execute instruction 

Instruction fetch 

Cache read, this CU cycle 

Memory read, this CU cycle 
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key Flag Name 



Meaning 



w MSTO 
x PIB 



Memory store, this CU cycle 
Memory port interface busy 



OPERATIONS UNIT (OU) HISTORY REGISTERS 



Format ; - 72 bits each 



Even word of Y-pair as stored by Store Central Processor Register (scpr). 
TAG =40 6 v ' 



111111111 
8 Q 1 ? 7, H 5 67 B 



RP REG 



OP CODE 



9 1 



m 



EAC 



3 1 1 



2 1 



2222333333 
6 - 7 . 8 . q .°- 1 - 2 .^. 4 . s 



RS REG 



9 111111111 



Odd word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG =40 y ' 



3 

i 


3 


3 
I 


3 
9 


4 

JO. 


4 
1 


4 
2 


4 
J. 


4 
4 


4 


4 


4 


4 

8 


4 
..2, 


5 
p 


5 
1 


5 
,3. 


5 
4 




n 


o 


P 


q 


r 


A 


Q 





T 


2 


3 


7 


5 


S 


7 








ICT TRACKER 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 




3 







""7T 



Figure 3-26. Operations Unit (OU) History Register Format 



Description ; 



A combination of 16 flags and registers from the operation unit and control 
unit. The 16 registers are handled as a rotating queue controlled by the 
operations unit history register counter. The counter is always set to the 
number of the oldest entry and advances by one for each history register 
reference (data entry or Store Central Processor Register (scpr) instruction). 



Function: 



An Operations Unit History Register entry shows the conditions at the end 
of the operations unit cycle to which it applies. The 16 registers hold 
the conditions for the last 16 operations unit cycles. As the operations 
unit performs various cycles in the execution of an instruction, it does 
not advance the counter for each such cycle. The counter is advanced only 
at successful completion of the instruction or if the instruction is aborted 
for a fault condition. Entries are made according to controls set in the 
Mode Register. (See Mode Register earlier in this section.) 
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The meanings of the constituent flags and registers are: 

key Flag Name Meaning 

RP REG Primary operations unit operation register. RP REG 
receives the operation code and other data for the next 
instruction from the control unit during the control 
unit instruction fetch cycle while the operations unit 
may be busy with a prior instruction. RP REG is further 
substructured as: 

OP CODE The 9 high-order bits of the 10-bit operation code from 
the instruction word. Note that basic (non EIS) 
instructions do not involve bit 27 hence the 9-bit field 
is sufficient to determine the instruction. 

a 9 CHAR Character size for indirect then tally address modifiers 

= 6-bit 

1 = 9-bit 

b TAG1,2,3 The 3 low-order bits of the address modifier from the 

instruction word. This field may contain a character 
position for an indirect then tally address modifier. 

c CR FLG Character operation flag 

d DR FLG Direct operation flag 

EAC Address counter for lreg/sreg instructions 

RS REG Secondary operations unit operation register. OP CODE 
is moved from RP REG to RS REG during the operand fetch 
cycle and is held until completion of the instruction. 

e RB1 FULL OP CODE buffer is loaded 

f RP FULL RP REG is loaded 

g RS FULL RS REG is loaded 

h GIN First cycle for all OU instructions 

i GOS Second cycle for multicycle OU instructions 

j GD1 First divide cycle 

k GD2 Second divide cycle 

1 GOE Exponent compare cycle 

m GOA Mantissa alignment cycle 

n GOM General operations unit cycle 

o GON Normalize cycle 

p GOF Final operations unit cycle 

q STR OP Store (output) data available 



t DA-AV Data not available 



A A-REG A register not in use 



C Q-REG Q register not is use 
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key Flag Name Meaning 






XO-RG 


XO not 
XI not 
X2 not 
X3 not 
X4 not 
X5 not 
X6 not 
X7 not 
The cui 


in use 


1 


XI -RG 


in use 


2 


X2-RG 


in use 


3 


X3-RG 


in use 


It 


X4-RG 


in use 


5 


X5-RG 


in use 


6 


X6-RG 


in use 


7 


X7-RG 

ICT TRACKER 


in use 
rrent v 



The current value of the instruction counter (PPR.IC). 
Since the Control Unit and Operations Unit run 
asynchronously and overlap is usually enabled, the value 
of ICT TRACKER may not be the address of the operations 
unit instruction currently being executed. 



DECIMAL UNIT (DU) HISTORY REGISTERS - DPS and L68 



Format: - 72 bits each 



Decimal Unit History Register data is stored with the Store Central Processor 
Register (scpr), TAG = 10, instruction. There is no format diagram because 
the data is defined as individual bits. 



Description : 



A combination of 16 flags from the decimal unit. The 16 registers are 
handled as a rotating queue controlled by the decimal unit history register 
counter. The counter is always set to the number of the oldest entry and 
advances by one for each history register reference (data entry or Store 
Central Processor Register (scpr) instruction). 

The decimal unit and the control unit run synchronously. There is a control 
unit history register entry for every decimal unit history register entry 
and vice versa (except for instruction fetch and EIS descriptor fetch cycles). 
If the processor is not executing a decimal instruction, the decimal unit 
history register entry shows an idle condition. 



Function: 



A decimal unit history register entry shows the conditions in the decimal 
unit at the end of the control unit cycle to which it applies. The 16 
registers hold the conditions for the last 16 control unit cycles. Entries 
are made according to controls set in the Mode Register. (See Mode Register 
earlier in this section.) 
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A minus (-) sign preceding the flag name indicates that the complement of 
the flag is shown. Unused bits are set ON. 

The meanings of the constituent flags are: 



bit 


Flag Name 





-FPOL 


1 


-FPOP 


2 


-MEED-DESC 


3 


-SEL-ADR 


4 


-DLENrDIRECT 


5 


-DFRST 


6 


-FEXR 


7 


-DLAST-FRST 


8 


-DDU-LDEA 


9 


-DDU-STAE 


10 


-DREDO 


11 


-DLVIXWD-SZ 


12 


-EXH 


13 


DEND-SEQ 


14 


-DEND 


15 


-DU=RD+WRT 


16 


-PTRA0O 


17 


-PTRA01 


18 


FA/11 


19 


FA/12 


20 


FA/13 


21 


-WRD 


22 


-NINE 


23 


-SIX 


24 


-FOUR 


25 


-BIT 


26 




27 




28 




29 





Meaning 

Prepare operand length 

Prepare operand pointer 

Need descriptor 

Select address register 

Length equals direct 

Descriptor processed for first time 

Extended register modification 

Last cycle of DFRST 

Decimal unit load 

Decimal unit store 

Redo operation without pointer and length update 

Load with count less than word size 

Exhaust 

End of sequence 

End of instruction 

Decimal unit write-back 

PR address bit 

PR address bit 1 

Descriptor 1 active 

Descriptor 2 active 

Descriptor 3 active 

Word operation 

9-bit character operation 

6-bit character operation 

4-bit character operation 

Bit operation 

Unused 

Unused 

Unused 

Unused 
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30 


FSAMPL 


31 


-DFRST-CT 


32 


-ADJ-LENGTH 


33 


-INTRPTD 


34 


-INHIB 


35 




36 


DUD 


37 


-GDLDA 


38 


-GDLDB 


39 


-GDLDC 


40 


NLD1 


41 


GLDP1 


42 


NLD2 


43 


GLDP2 


44 


ANLD1 


45 


ANLD2 


46 


LDWRT1 


47 


LDWRT2 


48 


-DATA-AVLDO 


49 


WRT1 


50 


GSTR 


51 


ANSTR 


52 


FSTR-OP-AV 


53 


-FEND-SEQ 


54 


-FLEJK128 


55 


FGCH 


56 


FANPK 


57 


FEXMOP 


58 


FBLNK 


59 




60 


DGBD 


61 


DGDB 


62 


DGSP 


63 


FFLTG 



Sample for mid-instruction Interrupt 

Specified first count of a sequence 

Adjust length 

Mid-instruction interrupt 

Inhibit STC1 (force "STCO") 

Unused 

Decimal unit idle 

Descriptor load gate A 

Descriptor load gate B 

Descriptor load gate C 

Prepare alignment count for first numeric operand load 

Numeric operand one load gate 

Prepare alignment count for second numeric operand load 

Numeric operand two load gate 

Alphanumeric operand one load gate 

Alphanumeric operand two load gate 

Load rewrite register one gate 

Load rewrite register two gate 

Decimal unit data available 

Rewrite register one loaded 

Numeric store gate 

Alphanumeric store gate 

Operand available to be stored 

End sequence flag 

Length less than 128 

Character operation gate 

Alphanumeric packing cycle gate 

Execute NOP gate 

Blanking gate 

Unused 

Binary to decimal execution gate 

Decimal to binary execution gate 

Shift procedure gate 

Floating result flag 
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64 


FRND 


65 


DADD-GATE 


66 


DMP+DV-GATE 


67 


DXPN-GATE 


68 




69 




70 




71 





Rounding flag 

Add/subtract execute gate 

Multiply/divide execution gate 

Exponent network execution gate 

Unused 

Unused 

Unused 

Unused 



DECIMAL/OPERATIONS UNIT (DU/OU) HISTORY REGISTERS - DPS 8M 



Format: - 72 bits each 



Even word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 40 









































































3 
4 


3 
5 1 


a 


b 


c 


d 


e 


f 


g 


h 


i 


J 


k 


1 


ra 


n 





P 


q 


r 


s 


t 


u 


V 


w 


X 


y 


z 


A 


B 


C 


D 


E 


F 


G 


H 


I 






35 1 

Odd word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 40 



3 
6 




5 
3 


5 
4 




6 
2 


6 
3. 


6 
4 


6 


6 
6 


6 

7 


6 
8 


6 
9 


7 



7 
1 


ICT 


RS REG 


J 


K 


L 


M 


N 





p 


Q 


R 






18 






9 


1 


1 


1 


1 


1 


1 


1 


1 


1 



Figure 3-27. Decimal/Operations (DU/OU) History Register Format - DPS 8M 



Description : 

A combination of 16 flags and registers from the operation unit and decimal 
unit. The 16 registers are handled as a rotating queue controlled by the 
operations unit history register counter. The counter is always set to the 
number of the oldest entry and advances by one for each history register 
reference (data entry or Store Central Processor Register (scpr) instruction). 

The decimal unit and the control unit run synchronously. There is a control 
unit history register entry for every decimal unit history register entry 
and vice versa (except for instruction fetch and EIS descriptor fetch cycles). 
If the processor is not executing a decimal instruction, the decimal unit 
history register entry shows an idle condition. 
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Function: 



An operations unit history register entry shows the conditions at the end 
of the operations unit cycle to which it applies. The 16 registers hold 
the conditions for the last 16 operations unit cycles. As the operations 
unit performs various cycles in the execution of an instruction, it does 
not advance the counter for each such cycle. The counter is advanced only 
at successful completion of the instruction or if the instruction is aborted 
for a fault condition. Entries are made according to controls set in the 
Mode Register. (See Mode Register earlier in this section.) 

The meanings of the constituent flags and registers are: 



key Flag Name 

a FANLD1 

b FANLD2 

c FANSTR 

d FLDWRT 1 

e FLDWRT2 

f FNLD1 

g FNLD2 

h NOSEQF 

i FDUD 

j FGSTR 

k NOSEQ 

1 NINE 

m SIX 

n FOUR 

o DUBIT 

p DUWORD 

q PTR1 

r PTR2 

s PRT3 

t FPOP 

u GEAM 

v LPD12 

w GEMAE 

x BTDS 

y SP15 

z FSWEQ 



Meaning 

Alpha-num load desc 1 (complemented) 

Alpha-num load desc 2 (complemented) 

Alpha-num store (complemented) 

Load re-write reg 1 (complemented) 

Load re-write reg 2 (complemented) 

Numeric load desc 1 (complemented) 

Numeric load desc 2 (complemented) 

End sequence flag 

Decimal unit idle (complemented) 

General store flag (complemented) 

End of sequence (complemented) 

9-bit character operation 

6-bit character operation 

4-bit character operation 

Bit operation 

Word operation 

Select ptr 1 

Select ptr 2 

Select ptr 3 

Prepare operand pointer 

Add timing gates (complemented) 

Load pointer 1 or 2 (complemented) 

Multiply gates A E (complemented) 

Binary to decimal gates (complemented) 

Align cycles (complemented) 

Single word sequence flag (complemented) 
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key Flag Name 



Meaning 



A FGCH 

B DFRST 

C EXH 

D FGADO 

E INTRPTD 

F GLDP2 

G GEMC 

H GBDA 

I GSP5 

ICT 

RS 
IR 

J ZERO 

K NEG 

L CARRY 

M OVFL 

N EOVFL 

EUFL 

P OFLM 

Q HEX 

R DTRGO 



Character cycle (complemented) 

Processing descriptor for first time 

Exhaust 

Add cycle (complemented) 

Interrupted 

Load DP2 

Multiply gate C 

Binary to decimal gate A 

Final align cycle 

Instruction counter (See NOTE below.) 

OU op-code register (RSO-8) 

Indicator register (IR): 

Zero indicator 

Negative indicator 

Carry indicator 

Overflow indicator 

Exponent overflow indicator 

Exponent underflow indicator 

Overflow mask indicator 

Hex mode indicator 

Transfer go 



NOTE: 



The current value of the instruction counter (PPR.IC). Since the control 
unit and operations unit run asynchronously and overlap is usually enabled, the 
value of ICT TRACKER may not be the address of the operations unit instruction 
currently being executed. 
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APPENDING UNIT (APO) HISTORY REGISTERS - DPS and L68 



Format ; 



72 bits each 



Even word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 00 









1 
4 


1 1 


1 
7 


1 

8 


1 
9 


2 

o 


2 

1 


2 

2 


2 

3. 


2 

4 


2 

5, 


2 2 
6 q 


3 



3 3 
1 4 


3 


ESN 


a 


b 


c 


d 


e 


f 


g 


h 


i 


J 


SDWAMR 


k 


PTWAMR 


1 






15 


2 


1 


1 


1 


1 


1 


1 


1 


1 


1 


4 


1 


4 


1 



Odd word of Y-pair as stored by Store Central Processor Register (scpr). 

TAG r 00 



56 66 666 677 
-2-Q L3 5_6_7 001 



ADD 



TRR 











"2T 



3 1 



3 1 1 



Figure 3-28. Appending Unit (APU) History Register Format - DPS and L68 



Description ; 

A combination of 16 flags and registers from the appending unit. The 16 
registers are handled as a rotating queue controlled by the appending unit 
history register counter. The counter is always set to the number of the 
oldest entry and advances by one for each history register reference (data 
entry or Store Central Processor Register (scpr) instruction). 



Function : 

An appending unit history register entry shows the conditions in the appending 
unit at the end of an address preparation cycle in appending mode. The 16 
registers hold the conditions for the last 16 such address preparation 
cycles. Entries are made according to controls set in the Mode Register. 
(See Mode Register earlier in this section.) 

The meanings of the constituent flags and registers are: 



key Flag name 
ESN 
a BSY 



Meaning 

Effective segment number (TPR.TSR) 

Data source for ESN 

00 = from PPR.PSR 

01 = from PRn.SNR 

10 = from TPR.TSR 

1 1 = not used 
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key Flag name 



Meaning 



b 
c 
d 
e 
f 

g 
h 
i 
J 



FDSPTW 

MDSPTW 

FSDWP 

FPTW 

FPTW2 

MPTW 

FANP 

FAP 

SDWAMM 

SDWAMR 

PTWAMM 

PTWAMR 

FLT 

ADD 

TRR 

CA 

FHLD 



Descriptor segment PTW fetch 

Descriptor segment PTW modification 

SDW fetch from paged descriptor segment 

PTW fetch 

PTW+1 fetch (prepaging for certain EIS instructions) 

PTW modification 

Final address fetch from nonpaged segment 

Final address fetch from paged segment 

SDWAM match occurred 

SDWAM register number if SDWAMMst 

PTWAM match occurred 

PTWAM register number if PTWAMM=1 

Access violation or directed fault on this cycle 

24-bit absolute main memory address from this cycle 

Ring number from this cycle (TPR.TRR) 

Multiple match error in SDWAM 

Segment is encacheable 

Multiple match error in PTWAM 

An access violation or directed fault is waiting 
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APPENDING UNIT (APU) HISTORY REGISTERS - DPS 8M 



Format: - 72 bits each 



Even word of Y-pair as stored by Store Central Processor Register (scpr), 
TAG = 00 





o 




1 
4 


1 


1 
6 


1 
7 


1 

8 


1 

9 


2 


2 
1 


2 

2. 


2 


2 
4 


2 
5. 


2 


2 2 

7 9 


2 

9 


3 3 
9 1 


3 
4 


3 

5 


ESN 


a 


b 


c 


d 


e 


f 


g 


h 


i 


J 


k 


1 


BSY 


m 


ml 


n 


o 



15 1 1 1 1 1 1 1 1 1 1 1 1 2 3 1 



4 1 



Odd word of Y-pair as stored by Store Central Processor Register (scpr). 
TAG =00 



5 6 6666666677 
Ar2 2_?_4 S_fi_7 a Q 1 



RMA 



2T 



3 1 2 11 2 11 



Extended APU History Register: 

Even word of Y-pair as stored by Store Central Processor Register (scpr). 
TAG =10 ' 









1 

7 


1 
8 




2 

7 


2 
§ 


2 
9 




3 
5 


ZCA 


Instr 


I 


MOD 






18 






10 


1 






7 



NOT USED 



IT 



Figure 3-29. Appending Unit (APU) History Register Format - DPS 8M 



Description ; 



A combination of 64 flags and registers from the appending unit. The 64 
registers are handled as a rotating queue controlled by the appending unit 
history register counter. The counter is always set to the number of the 
oldest entry and advances by one for each history register reference (data 
entry or Store Central Processor Register (scpr) instruction). 
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Function: 



An appending unit history register entry shows the conditions in the appending 
unit at the end of an address preparation cycle in appending mode. The 64 
registers hold the conditions for the last 64 such address preparation 
cycles. Entries are made according to controls set in the Mode Register. 
(See Mode Register earlier in this section.) 

The meanings of the constituent flags and registers are: 



key 


Flag name 




ESN 


a 




b 




c 


FDSPTW 


d 


MDSPTW 


e 


FSDW 


f 


FPTW 


g 


FPTW2 


h 


MPTW 


i 


FANP 


3 


FAP 


k 


MTCHSDW 


1 


SDWMF 




BSY 



m 


MTCHPTW 


ml 


PTWMF 


n 


PTWAM 





SDWMF 




RMA 


P 


RTRR 


q 


SDWME 


r 


SDWLVL 


s 


CACHE 


t 




u 


PTWLVL 



Meaning 

Effective segment number 

PIA Page overflow 

PIA out of segment bounds 

Fetch descriptor segment FTW 

Descriptor segment PTW is modified 

Fetch SDW 

Fetch PTW 

Fetch pre-page PTW 

PTW modified 

Final address nonpaged 

Final address paged 

SDW match found 

SDW match found and used 

Data source for ESN 

00 = from ppr.ic 

01 s from prn.tsr 

10 = from tpr.swr 

11 = from tpr.ca 

PTW match found (AM) 

PTW match found (AM) and used 

PTW AM direct address (ZCA bits 4-7) 

SDW match found 

Read 24 bit memory address 

Temporary ring register 

SDW match error 

SDW match level count (0 = Level A) 

Cache used this cycle 

PTW match error 

PTW match level count (0 = level A) 
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key Flag name Meaning 

v FLTHLD A directed fault or access violation fault is waiting 

ZCA Computed address 

INSTR Instruction executed 

I Inhibit bit 

MOD Instruction modifier 
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I CONFIGURATION SWITCH DATA - DPS and L68 



Format: - 36 bits each 



Data read by Read Switches (rsw), y = xxxxxO 



Maintenance panel data switches 



"3* 



Data read by Read Switches (rsw), y = xxxxx2 




3 4 5 6 



1 2 
22. 



1 1 2 

8.9.Q 



2 2 2 2 3 3 3 
6 7 8 9 2 3 5. 







FAULT BASE 











CPU 

ID 



CPU 



U 2 



61 



Data read by Read Switches (rsw), y = xxxxxl (port A-D) or xxxxx3 (port E-H) 












1 1 
7 8 



2 2 
6 7 



PORT A or E 



PORT B or F 



PORT C or G 



EEH 



PORT D or H 



m 



ADR 



033 



MEM 



ADR Ic 



33 



MEM 



ADR 



MEM 



ADR Ic 



MEM 



3 111 



3 111 



3 111 



3 111 



Data read by Read Switches (rsw), y = xxxxxl 



111111112222222222 
■?_■>, M 6_7 8_Q 1 2 3 4_S fi_7 8_Q 



000000000000 



L 



A B C D E F G H 

f | g|f|g|f|g|f|g|f[g|f{gK|g|f|g 







13 n Ti ri n n 11 1111 



Figure 3-30. Configuration Switch Data Formats - DPS and L68 



Description: 



The Read Switches (rsw) instruction provides the ability to interrogate 
various switches and options on the processor maintenance and configuration 
panels. The 3 low-order bits of the computed address (TPR.CA) select the 
switches to be read. High-order address bits are ignored. Data are placed 
in the A Register. 

Read Switches (rsw), y = xxxxxl reads data for ports A, B, C, and D. Read 
Switches (rsw), y = xxxxx3 reads data for ports E, F, G, and H. 
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Function: 



The meanings of the constituent fields are: 

key Field name Meaning 
a CPU-Type Equals "00" for a L68 or a DPS processor. 

FLT BASE The seven MSB of the 12-bit fault base address 

b dps_jjption Processor option 

= L68 processor 

1 = DPS processor 

c cache 2K cache option 

= disabled 

1 = enabled 

d ext_gcos GCOS mode extended memory option 

= disabled 

1 = enabled 

CPU ID These bit positions have a configuration of '* 1 1 1 " s for 

a L68 or a DPS CPU. 

CPU Processor number from processor configuration panel number 

switches. 

PORT A or E, Port data fields further substructured as: 
etc. 

ADR Address assignment switch setting for port 

c Port enabled flag 

d System initialize enabled flag 

e Interlace enabled flag 

MEM Coded memory size . . . 



000 


32K 


001 


64K 


010 


128K 


011 


256K 


100 


512K 


101 


1024K 


110 


2048K 


111 


4096K 



I 



I 



A, B, etc. Port data fields further substructured as: 

Interlace mode 

0=4 word if interlace enabled for port 
1 = 2 word if interlace enabled for port 

Main memory size 

= full, all of MEM is configured 

1 = half, half of MEM is configured 
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CONFIGURATION SWITCH DATA - DPS 8M 



The following changes apply to the DPS 8M processor. 



Format: - 36 bits each 



Data read by Read Switches (rsw), y = xxxxx2 





n 








3 




4 5 


1 
6 2 


1 

3 


1 1 
4 7 


1 

8 


1 

9 


2 



2 2 
1 2 


2 

3 


2 

4 


2 

5 


2 2 
6 8 


2 3 

9 2 


3 3 
3 5 


A 


B 


C 


D 


b 


FLT BASE 


e 





d 


e 


f 





e 


h 


i 





SPEED 


CPU 


a 


a 


a 


a 








4 


2 


7 


1 


4 


1 


1 


1 


2 


1 


1 


1 


3 


4 


3 



Data read by Read Switches (rsw), y = xxxxxl (port A-D) 





11 



1 1 

7 



PORT A 



m 



ADR j k 11 MEM 



3 111 



PORT B 



ADR 



333 



3 111 



1| MEM 



2 2 



PORT C 



ADR 



3 



wm. 



MEM 



3 111 



2 *I 

PORT D I 

ADR |j|k|l| MEM { 



3 111 



Figure 3-31. Configuration Switch Data Formats - DPS 8M 



Description : 



The Read Switches (rsw) instruction provides the ability to interrogate 
various switches and options on the processor maintenance and configuration 
panels. The two low-order bits of the computed address (TPR.CA) select the 
switches to be read. High-order address bits are ignored. Data are placed 
in the A Register. 

Read Switches (rsw), y = xxxxxl reads data for ports A, B, C, and D. 



Function: 



The meanings of the constituent fields are: 



key Field name 

a 



Meaning 

If the corresponding rswl interface enabled flag, bit 
(e) is ON, then 

0=4 word interfaces 

I = 2 word interfaces 
For ports A-D 

Indicates processor type 

00 = L68 or DPS Processor 

01 = DPS 8M Processor 

10 = reserved for future use 

II = reserved for future use 
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key Field name Meaning 



FLTBASE The seven MSB of the 12-bit fault base address 

c ID prom 

= id prom not installed 

1 = id prom installed 

d BCD option (Marketing designation) 

1 = BCD option installed 

e DPS option (Marketing designation) 

1 = DPS option 

f 8K cache 

1 = 8K cache installed 

g DPS 8M Processor type designation 

1 = DPS 8/xxM 

= DPS 8/xx 

h GCOS/VMS switch position 

1 = Virtual Mode 

= GCOS Mode 

i Current or new product line peripheral type 

1 = NPL 
= CPL 

SPEED Processor speed options 

0000 = 8/70 
0100 = 8/52 

CPU Processor number 

ADR 

j Port enabled flag 

k System initialize enabled flag 

1 Interface enabled flag 

MEM Coded memory size: 

000 32K 

001 64K 

010 128K 

011 256K 

100 512K 

101 1024K 

110 2048K 

111 1096K 
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CONTROL UNIT DATA 



Format: - 288 bits, 8 machine words 



Data as stored by Store Control Unit (scu) instruction 



Word 




2 







1 
7 


1 


1 
9 


2 

Q 


2 
1 


2 

2 


2 
3 


2 

4, 


2 


2 
6" 


2 

7 


2 
8 


2 

-2. 


3 
9 


3 
1 


3 
2. 


3 3 
3 5 


PRR 


PSR 


a 


b 


c 


d 


e 


f 


g 


h 


i 


j 


k 


1 


m 


n 





FCT 


3 






15 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


3 








1 



? 




3 




4 






6 




7 



8 




q 


i 




1 

1 


1 

2 


1 

3 


1 
4 


1 
5 


1 
6 


1 

7 


1 
8 


1 
q 


2 



2 
3. 


2 2 
4 6 


2 2 

j a. 


3 3 
4 


3 

i 


a 


b 


c 


d 


e 


f 


g 


h 


i 


j 


k 


1 


m 


n 


o 


P 


q 


r 


s 


t 


IA 


IACHN 


CNCHN 


F/I ADDR 


u 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 




4 


3 


3 


5 


1 




2 3 



TRR 



11122222222 23 
7 8 9 1 2 3 4 567 Q 



TSR 



PTW 



abed 



SDW 



e f g h 



CPU 



DELTA 



15 

1 1 
7 8 



000000000000000000 



"IS 



2 2 2 

o 1.2 



TSNA 



4 1 

2 2 2 
4 5 6 



TSNB 



J\> a [b a | 



3 1 



3 1 



2 2 3 
8 Q 



TSNC 



TEMP BIT 



3 1 



1 









1 

7 


1 
8 


1 

9 


2 



2 

1 


2 
2 


2 

1 


2 
4 


2 


2 

6 


2 

7 


2 

8 


2 


3 



3 

1 


3 
2 


3 

5, 


IC 


a 


b 


c 


d 


e 


f 


g 


h 


i 


j 


k 


1 


m 


n 












18 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 




4 









1 


1 

8 


1 

9 


2 

o 


2 

1 


2 
? 


2 

3 


2 
4 


2 

5. 


2 
6 


2 

7 


2 
8 


2 
9 


3 3 
5 


COMPUTED ADDRESS 


a 


b 


c 


d 


e 


f 


g 


h 


i 


j 


k 


1 


CT HOLD 






ifi 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 6 









1 1 
7 8 




2 

L 


2 
8 


2 

JL 


3 





3 


ADDRESS 


OPCODE 


I 


p 


TAG 1 






18 






10 


1 


1 






b 









1 
7 


1 
8 




2 2 
7 8 


2 3 3 
Q 5 




ADDRESS 


- ' T8 




OPCODE 


I 
10 1 


P TAG j 

i ■ o' 



Figure 3-32. Control Unit Data Format 
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Description: 



A collection of flags and registers from the appending unit and the control 
unit- In general, the data has valid meaning only when stored with the 
Store Control Unit (scu) instruction as the first instruction of a fault or 
interrupt trap pair. 



Function: 



The control unit data allows the processor to restart an instruction at the 
point of interruption when it is interrupted by an access violation fault, 
a directed fault, or (for certain EIS instructions) an interrupt. Directed 
faults are intentional, and most access violation faults and interrupts are 
recoverable. If the interruption is not recoverable, the control unit data 
provides enough information to determine the exact nature of the error. 

Instruction execution restarts immediately upon execution of a Restore Control 
Unit (rcu) instruction referencing the Y-block8 area into which the control 
unit data was stored. 

Fields having an "x" in the column headed L are not restored by the Restore 
Control Unit (rcu) instruction. 

The meanings of the constituent fields are: 









Field 


Word 


key 


L 


name 









PRR 









PSR 





a 




P 





b 




XSF 





c 


X 


SDWAMM 





d 


X 


SD-ON 





e 


X 


PTWAMM 





f 


X 


PT-ON 





g 


X 


PI-AP 





h 


X 


DSPTW 





i 


X 


SDWNP 





J 


X 


SDWP 





k 


X 


PTW 





1 


X 


PTW2 





m 


X 


FAP 





n 


X 


FANP 





o 


X 


FABS 









FCT 



Meaning 

Procedure ring register (PPR.PRR) 

Procedure segment register (PPR.PSR) 

Privileged bit (PPR.P) 

External segment flag 

Match on SDWAM 

SDWAM enabled 

Match on PTWAM 

PTWAM enabled 

Instruction fetch append cycle 

Fetch descriptor segment PTW 

Fetch SDW - nonpaged 

Fetch SDW - paged 

Fetch PTW 

Fetch prepage PTW 

Fetch final address - paged 

Fetch final address - nonpaged 

Fetch final address - absolute 

Fault counter - counts retries 
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Field 
Word key L name Meaning 



a 


X 


IRO 




X 


ISN 


b 


X 


OEB 




X 


IOC 


c 


X 


E-OFF 




X 


IA + IM 


d 


X 


ORB 




X 


ISP 


e 


X 


R-OFF 




X 


IPR 


f 


X 


OWB 




X 


NEA 


g 


X 


W-OFF 




X 


OOB 


h 


X 


NO GA 


i 


X 


OCB 


J 


X 


OCALL 


k 


X 


BOC 


1 


X 


PTWAM ER 



m x CRT 

n x RALR 

o x SDWAM_ER 

p X OOSB 

q x PARU 

r x PARL 

s x ONC1 

t x ONC2 

x IA 

x IACHN 
x CNCHN 
x F/I ADDR 
u x F/I 



For access violation fault - illegal ring order 
For store fault - illegal segment number 

For access violation fault - out of execute bracket 
For illegal procedure fault - illegal op code 

For access violation fault - execute bit is OFF 

For illegal procedure fault - illegal address or modifier 

For access violation fault - out of read bracket 

For illegal procedure fault - illegal slave procedure 

For access violation fault - read bit is OFF 
For illegal procedure fault - illegal EIS digit 

For access violation fault - out of write bracket 
For store fault - nonexistent address 

For access violation fault - write bit is OFF 
For store fault - out of bounds (BAR mode) 

For access violation fault - not a gate 

For access violation fault - out of call bracket 

For access violation fault - outward call 

For access violation fault - bad outward call 

For access violation fault - on DPS 8M processors, a 
PTW associative memory error. Not used on DPS/L68 
processors. 

For access violation fault - cross ring transfer 

For access violation fault - ring alarm 

For access violation fault - On DPS 8M an SDW associative 
memory error. An associative memory error on DPS/L68. 

For access violation fault - out of segment bounds 

For parity fault - processor parity upper 

For parity fault - processor parity lower 

For operation not complete fault - processor/system 
controller sequence error #1 

For operation not complete fault - processor/system 
controller sequence error #2 

System controller illegal action lines (see Table 3-1) 

Illegal action processor port 

For connect fault - connect processor port 

Modulo 2 fault/interrupt vector address 

Fault/interrupt flag 

= interrupt 

1 = fault 
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Field 


Word 


key 


L name 


2 




TRR 


2 




TSR 
PTW 


2 


a 


X 


2 


b 


X 


2 


c 


X 


2 


d 


c 



Meaning 

Temporary ring register (TPR.TRR) 

Temporary segment register (TPR.TSR) 

DPS 8M processors only; this field mbz on DPS/L68 
processors: 

PTWAM levels A, B enabled (enabled = 1) 
PTWAM levels C, D enabled 
PTWAM levels A, B match (match r 1) 
PTWAM levels C, D match 

SDW DPS 8M processors only; this field mbz on DPS/L68 
processors: 

2 e x SDWAM levels A, B enabled 

2 f x SDWAM levels C, D enabled 

2 g x SDWAM levels A, B match 

2 h x SDWAM levels C, D match 

2 CPU CPU number 

2 DELTA Address increment for repeats 

3 TSNA Pointer register number for non-EIS operands or for EIS 

operand #1 further substructured as: 

3 a PRNO Pointer register number 
3 b 1 = PRNO is valid 

3 TSNB Pointer register number for EIS operand #2 further 
substructured as for TSNA above 

3 TSNC Pointer register number for EIS operand #3 further 
substructured as for TSNA above 

TEMP BIT Current bit offset (TPR.TBR) 
Instruction counter (PPR.IC) 

Zero indicator 

Negative indicator 

Carry indicator 

Overflow indicator 

Exponent overflow indicator 

Exponent underflow indicator 

Overflow mask indicator 

Tally runout indicator 

Parity error indicator 

Parity mask indicator 

Not BAR mode indicator 
EIS truncation indicator 

MIF Mid-instruction interrupt indicator 
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3 
4 




TEMP 
IC 


4 


a 


ZERO 


4 


b 


NEG 


n 


c 


CARY 


4 


d 


OVFL 


4 


e 


EOVF 


4 


f 


EUFL 


4 


g 


OFLM 


4 


h 


TRO 


4 


i 


PAR 


4 


i 


PARM 


4 
4 


k 

1 


BM 
TRU 



Field 
Word key L name Meaning 



4 


n 


ABS 


1 

5 


o 


HEX 
x CA 


5 


a 


RF 


5 


b 


RPT 


5 


c 


RD 


5 


d 


RL 


5 


e 


POT 



5 


g 


XDE 


5 


h 


XDO 


5 


i 


ITP 


5 


J 


RFI 


5 


k 


ITS 


5 


1 


FIF 


5 




CT 


6 







Absolute mode Indicator 

Hex mode indicator (DPS 8M processors only) 

Current computed address (TPR.CA) 

First cycle of all repeat instructions 

Execute a Repeat (rpt) instruction 

Execute a Repeat Double (rpd) instruction 

Execute a Repeat Link (rpl) instruction 

Prepare operand tally. This flag is up until the indirect 
word of an indirect then tally address modifier is 
successfully fetched. 

PON Prepare operand no tally. This flag is up until the 
indirect word of a return type transfer instruction is 
successfully fetched. It indicates that there is no 
indirect chain, even though an indirect fetch is being 
performed. 

Execute instruction from Execute Double even pair 

Execute instruction from Execute Double odd pair 

Execute ITP indirect cycle 

Restart this instruction 

Execute ITS indirect cycle 

Fault occurred during instruction fetch 

CT HOLD Contents of the modifier holding register 

Word 6 is the contents of the working instruction register 
and reflects conditions at the exact point of address 
preparation when the fault or interrupt occurred. The 
ADDRESS and TAG fields are replaced with data from pointer 
registers, indirect pointers, and/or indirect words during 
each indirect cycle. Each instruction of the current 
pair is moved to this register before actual address 
preparation begins. 

Word 7 is the contents of the instruction holding register. 
It contains the odd word of the last instruction pair 
fetched from main memory. Note that, primarily because 
of overlap, this instruction is not necessarily paired 
with the instruction in word 6. 
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DECIMAL UNIT DATA 



Format: - 288 bits, 8 machine words 



Data as stored by Store Pointers and Lengths (spl) instruction 



Word 




o 8 




9 


1 



1 
1 


1 
2 


000 000000 


z 


a 








CH TALLY 



9 111 



"2T 



3 

-5 


000000000000000000000000000000000000 


36 









2 

3 


2 

4 


2 2 
<j 6 


2 2 

7 Q 


3 
p 


3 


3 
2 


3 3 
1 5 


D1 PTR 





TA 





I 


F 


A 









2k 


1 


2 


3 


1 


1 


1 


3 



111 
9 12 



LEVEL 1 







D1 RES 



10 



24 









2 

3 


2 
4. 


2 2 


2 2 
7 Q 


3 



3 
1 


3 
2 


3 


3 
4. 


3 


D2 PTR 





TA 





R 


F 


A 















24 


1 


2 


3 


1 


1 


1 


1 


1 


1 








111 
9.Q 1,2 



3 



LEVEL 2 







D2 RES 



10 









2 

3 


2 
1 


2 2 2 2 

5 6 7 Q 


3 
P 


3 
1 


3 
2 


3 3 


D3 PTR 





TA 





R 


F 


A 


JMP 






24 


1 


2 


3 


1 


1 


1 


3 



1 
1 


1 




3 


000000000000 


D3 RES 


12 






24 



Figure 3-33. Decimal Unit Data Format 
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Description; 



A collection of flags and registers from the decimal unit, 



Function: 



The decimal unit data allows the processor to restart an EIS instruction at 
the point of interruption when it is interrupted by an access violation 
fault, a directed fault, or (for certain EIS instructions) an interrupt. 
Directed faults are intentional, and most access violation faults and interrupts 
are recoverable. 

The data are restored with the Load Pointers and Lengths dpi") instruction. 
Fields having an "x" in the column headed L are not restored. When starting 
(or restarting) execution of an EIS instruction, the decimal unit registers 
and flags are not initialized from the operand descriptors if the 
mid-instruction interrupt fault (MIF) indicator is set ON. 

The meanings of the constituent flags and registers are: 







Field 


Word 


L 


name 







z 















CHTALLY 



2 D1 PTR 

2,4,6 TA 
2x1 

2,4,6 F 
2,4,6 A 

3 LEVEL 1 



D1 RES 
D2 PTR 



4,6 x R 

5 LEVEL 2 

5 D2 RES 

6 D3 PTR 



Meaning 

All bit-string instruction results are zero 

Negative overpunch found in 6-4 expanded move 

The number of characters examined by the scm, scmr, 
scd, scdr, tct, or tctr instructions (up to the interrupt 
or match) 

Address of the last double-word accessed by operand 
descriptor 1; bits 17-23 (bit-address) valid only for 
initial access 

Alphanumeric type of operand descriptor 1,2,3 

Decimal unit interrupted flag; a copy of the 
mid-instruction interrupt fault indicator 

First time; data in operand descriptor 1,2,3 is valid 

Operand descriptor 1,2,3 is active 

Difference in the count of characters loaded into the 
processor and characters not acted upon 

Count of characters remaining in operand descriptor 1 

Address of the last double-word accessed by operand 
descriptor 2; bits 17-23 (bit-address) valid only for 
initial access 

Last cycle performed must be repeated 

Same as LEVEL 1, but used mainly for OP 2 information 

Count of characters remaining in operand descriptor 2 

Address of the last double-word accessed by operand 
descriptor 3; bits 17-23 (bit-address) valid only for 
initial access 
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Field 
Word L name Meaning 



6 JMP Descriptor count; number of words to skip to find the 

next instruction following this multiword instruction 

7 D3 RES Count of characters remaining in operand descriptor 3 
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SECTION 4 
MACHINE INSTRUCTIONS 



This section describes the complete set of machine instructions for the 
Multics processor. The presentation assumes that the reader is familiar with 
the general structure of the processor, the representation of information, the 
data formats, and the method of address preparation. Additional information on 
these subjects appears near the beginning of this section and in Sections 2, 3, 
5 , and 6 . 



INSTRUCTION REPERTOIRE 

The processor interprets a 10-bit field of the instruction word as the 
operation code. This field size yields 1021 possible instructions of which 547 
are implemented. There are 456 basic operations and 91 extended instruction set 
(EIS) operations. 



Arrangement of Instructions 

Instructions are presented alphabetically by their mnemonic codes within 
functional categories. An overall alphabetic listing of instruction codes and 
their names appears in Appendix B. 



Basic Operations 

The 456 basic operations in the processor all require exactly one 36-bit 
machine word. They are categorized as follows: 

181 Fixed-point binary arithmetic 

85 Boolean operations 

34 Floating-point binary arithmetic 

36 Transfer of control 

75 Pointer register 

17 Miscellaneous 

28 Privileged 



Extended Instruction Set (eis) Operations 

The 91 extended instruction set (EIS) operations are divided into 62 EIS 
single-word instructions and 29 EIS multiword instructions. 
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EIS SINGLE-TORD OPERATIONS 

xr-i^Vltif 2 EIS * in 8 1 V; word instructions load, store, and perform special 
Xi2;?«.*,. - n the a j ,dress registers (ARn) used to access bit- and 
reau?r«f;f ,i"L° PerandS ' and s ffe-store decimal unit (DU) control information 
E?s iT«2i - J^ ■ \ processor fault or interrupt. Like the basic operations, 
EIS single-word instructions require exactly one 36-bit machine word. 

EIS MULTIWORD OPERATIONS 

„w,.., T !? e 29 < . E . IS multiword instructions perform decimal arithmetic and bit- and 
HinI a H^" S ^- n 5, °P era , tions - They require three or four 36-bit machine words 
depending on individual operand descriptor requirements. 

FORMAT OF INSTRUCTION DESCRIPTION 

tM , ^ach instruction in the repertoire is described in the following pages of 
this section. The descriptions are presented in the format shown below. 



MNEMONIC 



INSTRUCTION NAME 



OPCODE 



U 



FORMAT: Figure or figure reference 

SUMMARY: Text and/or bit transfer equations 

MODIFICATIONS: Text 

INDICATORS: Text and/or logic statements 

NOTES: Text 

Line 1: MNEMONIC. INSTRUCTION NAME. OPCODE 

This line has three parts that contain the following: 

1. MNEMONIC — The mnemonic code for the operation field of the assembler 
statement. The Multics assembler, ALM, recognizes this character 
string value and maps it into the appropriate binary pattern when 
generating the actual object code. 

2. INSTRUCTION NAME — The name of the machine instruction from which the 
mnemonic was derived. 

3. OPCODE — The octal value of the operation code for the instruction. 
A or a 1 in parentheses following an octal code indicates whether 
bit 27 (opcode extension bit) of the instruction word is OFF or ON. 



4-2 AL39 



Line 2: FORMAT 

The layout and definition of the subfields of the instruction word or words 
are given here either as a figure or as a reference to a figure. 



Line 3: SUMMARY 

The change in the state of the processor effected by the execution of the 
instruction is described in a short, symbolic form. If reference is made to the 
state of an indicator in the summary, it is the state of the indicator before 
the. instruction is executed. 



Line 4: MODIFICATIONS 

Those modifiers that cannot be used with the instruction are listed 
explicitly as exceptions. See Section 6 for a discussion of address 
modification. 



Line 5: INDICATORS 

Only those indicators are listed whose state can be changed by the 
execution of the instruction. In most cases, a condition for setting ON as well 
as one for setting OFF is stated. If only one of the two is stated, then the 
indicator remains unchanged if the condition is not met. Unless stated 
otherwise, the conditions refer to the contents of registers existing after 
instruction execution. Refer also to "Common Attributes of Instructions," later 
in this section. 



Line 6: NOTES 

This part of the description exists only in those cases where the summary 
is not sufficient for in-depth understanding of the instruction. 
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DEFINITIONS OF; NOTATION AND SYMBOLS 



Main Memory Addresses 



y 

Y 
Y-pair 



Y-blockn 



Y-charnk 



Y-bitk 



an 18-bit computed address as generated during address 
preparation. 

a 24-bit main memory address of the instruction operand 
after all address preparation (including appending) is 
complete. 

a pair of main memory locations with successive 
addresses, the smaller address being even. When Y is 
even, it designates the pair Y(even), Y+1 ; and when it 
is odd, the pair Y-1 , Y(odd) . The main memory location 
with the smaller (even) address contains the most 
significant part of a double-word operand or the first 
of a pair of instructions. 

a block of main memory locations of 4-, 8-, 16-, or 
32-word extent. For a block of n-word extent, the 
processor forces Y-blockn to a modulo n address and 
performs address incrementing through the block 
accordingly, stopping when the address next reaches a 
value modulo n. 

a character or string of characters in main memory of 
character size n bits as described by the kth operand 
descriptor. n is specified by the data type field of 
operand descriptor k and may have values 4, 6, or 9. 
See Section 6 for details of operand descriptors. 

a bit or string of bits in main memory as described by 
the kth operand descriptor. See Section 6 for details 
of operand descriptors. 



Index Values 



When reference is made to the elements of a string of characters or bits in 
main memory, the notation shown in "Register Position and Contents" below is 
used. The index used to show traversing a string of extent n may take any of 
the values in the interval (1,n) unless noted otherwise. The elements of a main 
memory block are traversed explicitly by using the index as an addend to the 
given block address, (e.g., Y-block8+m and Y-block4+2m+1 ) . 



Abbreviations and Symbols 



A Accumulator register 

ARn Address register n (n = 0, 1, 2, ..., 7) 

AQ Combined accumulator-quotient register 

BAR Base address register 

CO "Contents of" 

CA Computed address 

DSBR Descriptor segment base register 

DSBR.ADDR Address field of DSBR 

DSBR.BND Bound field of DSBR 

DSBR. STACK Stack base field of DSBR 

DSBR.U Unpaged flag of DSBR 
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E Exponent register 

EA Combined exponent-accumulator register 

EAQ Combined exponent-accumulator-quotient register 

ERN Effective ring number 

ESN Effective segment number 

IC Instruction counter 

IR Indicator register 

PPR Procedure pointer register 

PPR.PRR Procedure ring register of PPR 

PPR.PSR Procedure segment register of PPR 

PPR.IC Instruction counter register of PPR (same as IC above) 

PPR.P Privileged flag of PPR 

PRn Pointer register n (n = 0, 1 , 2, . . . , 7) 

PRn.RNR Ring number register of PRn 

PRn.SNR Segment number register of RRn 

PRn.WORDNO Word address register of PRn 

PRn. CHAR Character address register of PRn 

PRn.BITNO Bit offset register of PRn 

Q Quotient register 

PTWAM' Page table word associative memory 

SDWAM Segment descriptor word associative memory 

RALR Ring alarm register 

TPR Temporary pointer register 

TPR.CA Computed address register of TPR (same as CA above) 

TPR.TRR Temporary ring register of TPR 

TPR.TSR Temporary segment register of TPR 

TPR.TBR Temporary bit register of TPR 

TR Timer register 

Xn Index register n (n = 0, 1,2, . .., 7) 

Z Temporary pseudo-result of a nonstore comparative operation 



Register Positions and Contents 

In the definitions that follow, »'R n stands for any of the registers listed 
above, as well as for main memory words, word-pairs, word-blocks, and bit- or 
character-strings. 



R i 
R(i) 



C(R) 

C(R)i 

C(R) ifj 



The i th bit, character, or byte position of R 

The i tn register of a set of n registers named R 

The bit, character, or byte positions i through j of R 

The contents of the full register R 

The contents of the i tn bit, character, or byte of R 

The contents of the bits, characters, or bytes i through j of R | 

A string of binary bits (0's or 1's) of any necessary length 



I 



When the description of an instruction specifies a change for a part of a 
register or main memory location, it is understood that the part of the register 
or main memory location not mentioned remains unchanged. 



Other Symbols 



-> 



replaces 
compare with 
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& the Boolean connective AND 

! the Boolean connective OR 

» the Boolean connective NON-EQUIVALENCE (or EXCLUSIVE OR) 

XXX the logical inverse (ones complement) of the quantity XXX 

■i not equal 

n**m indicates exponentiation (n and m are integers); for 

example, the fifth power of 2 is represented as 2**5. 

X multiplication; for example, C(Y) times C(Q) is represented 

as C(Y) Xc(Q). 

/ division; for example, C(Y) divided by C(A) is represented 

as C(Y) /c(A). 

!! concatenation; for example, stringl !! string2. 

|...j the absolute value of the value between vertical bars (no 

algebraic sign). For example the absolute value of C(A) plus 

C(Y) is represented as: Jc(A) + C(Y)j. 

C ^ R ^modn A coined notation for remaindering' or modulo arithmetic; for 

- example C(REG) modulo 9 is represented as c ( REG ) mo d9- 

COMMON ATTRIBUTES OF INSTRUCTIONS 



Illegal Modification 

If an illegal modifier is used with any instruction, an illegal procedure 
fault with a subcode class of illegal modifier occurs. 



Parity Indicator 

The parity indicator is turned ON at the end of a main memory access that 
has incorrect parity. 



INSTRUCTION WORD FORMATS 



Basic and EIS Single-Word Instructions 

The basic instructions and EIS single-word instructions require exactly one 
36-bit machine word and are interpreted according to the format shown in Figure 
4-1. 



4-6 AL39 



1 1 



ADDRESS 



1i 



OPCODE 



2 2 2 3 

7_8 q n 



_L 



10 1 1 
Figure 2|-i. Basic and EIS Single-Word Instruction F 



3 



TAG 



orraat 



ADDRESS 



ad h d e re g sr;a;t: eSS ° f "* ° Perand ° r indireCt word ■ "us 
JabsoluteVdeTnfvl ^ ""^ 3ddreSS if A = ° 

i? i^ss^r^r to the base address -« ist - 

nrJ 8 J bit ° ffSet relativ e to the base of the current 
procedure segment If A = (appending mode only) 



A 3-bit pointer register number (n) and a 15-bit offsp 
relative to C(PRn.WORDNO) if A " = 1 (absolute an 
appending modes only) u SOiUle an 



et 

d 



reilHL ad t d n e r?^ iS \ er " Umber ( ^ and a 1 5-bit offset 
inllti:tio\\ C y£f ) lf A = 1 (al1 m ° des spending on 

An 18-bit literal signed or unsigned constant (all 
modes depending on instruction type and modifier) 

An 8-bit shift operation count (all modes) 

?" J?~ b ^ offset relative to the current value of the 
instruction counter C(PPR.IC) (all modes) 



OPCODE 



Instruction operation code. 



Interrupt inhibit bit. When this bit is set ON the 

Sec?!on°7 fir' 1 'f'^ a11 6Xternal -terrupt signals.' e 
bection 7 for a discussion of interrupts. 



See 



Indirect via pointer register flag. See Section 6 for a 
discussion of the use of pointer registers. 



TAG 



Instruction address modifier. See Section 
discussion of address modification. 



for 



pseudo-instruction). 1Dea iater ln thls section) and the arg 



Indirect Words 
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specified, C(Y) is interpreted as an indirect word according to the format shown 
in Figure 4-2. 









1 
7 


1 
8 




2 

9 


3 





3 
5 


ADDRESS 


TALLY 


TAG 






18 






12 






6 



Figure 4-2. Indirect Word Format 



ADDRESS 



TALLY 
TAG 



The given address of the operand or next indirect word. This 
address may be: 

An 18-bit absolute main memory address if A = in the 
instruction word (absolute mode only) 

An 18-bit offset relative to the base address register 
(BAR) if A = in the instruction word (BAR mode only) 

An 18-bit offset relative to the base of the segment in 
which the word resides if A = (appending mode only) 

Three zero bits and a 15-bit segment number if 
TAG = (^3)3 (its modification) (absolute and 
appending modes only) 

A 3-bit pointer register number and 15 zero bits if 
TAG r (41)g dtp modification) (absolute and 
appending modes only) 

A count field for use by those address modifiers that involve 
tallying 

This field may be (depending on the TAG value causing the 
indirection) ; 



A 6-bit address modifier 

A 6-bit increment to be added to or subtracted from ADDRESS 
on each reference 

A 1-bit character mode (6- or 9-bit) flag, two bits, and 
a 3-bit character position number 

Machine words in this format may be generated by use of the ALM vfd 
pseudo-instruction . 



EIS Multiword Instructions 

The EIS multiword instructions require three or four machine words depending 
on the operand descriptor requirements of the individual instructions. The words 
are interpreted according to the format shown in Figure 4-3. The instruction 
descriptions (later in this section) contain ALM coding examples. Refer to the MPM 
Subsystem Writers' Guide , Order No. AK92, "aim Command" for additional 
information . 
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1 1 
_L 



VARIABLE 



2 2 2 

7 8 q 



OPCODE 



MF1 



18 10 1 

operand descriptor or indirect pointer for operand 1 



operand descriptor or indirect pointer for operand 2 



operand descriptor or indirect pointer for operand 3 



36 



VARIABLE 



OPCODE 



MF1 



Figure 4-3. EIS Multiword Instruction Format 



This field is interpreted variously according to 
requirements of the individual EIS instructions. 



interpretation is given under FORMAT for each 
instruction. The modification fields MF2 and 
contained in this field if they are required 



MF3 



Instruction operation code 
single-word instructions. 



the 
Its 
EIS 
are 



as for basic and EIS 



Interrupt inhibit bit as for basic and EIS single-word 
instructions. 



Modification field for operand descriptor 1 
modification fields (MF) below for details. 



See EIS 



Machine words in this format are generated by ALM in processing the EIS 
multiword instructions described later in this section and Ttneir associated 
operand descriptor or indirect pointer pseudo-operations. associated 



EIS Modification Fields (MF) 





















12=? 




6 


a 


b 


c 


REG 



1 1 1 



Figure 4-4. EIS Modification Field (MF) Format 



key 

a AR 



A r d !T S „nnf^ S o e £. flag> This fla S controls interpretation 
of the ADDRESS field of the operand descriptor just as the 
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b RL 



c ID 



REG 



"A" flag controls Interpretation of the ADDRESS field of the 
basic and EIS single-word instructions. The ALM coding 
mnemonic for this flag is "pr". 

Register length control. If RL = 0, then the length (N) field 
of the operand descriptor contains the length of the 
operand. If RL = 1, then the length (N) field of the operand 
descriptor contains a selector value specifying a register 
holding the operand length. Operand length is interpreted as 
units of the data size (1-, 4-, 6-, or 9-bit) given in the 
associated operand descriptor. The ALM coding mnemonic for 
this flag is "rl". 

Indirect descriptor control. If ID : 1 for MFk, then the kth 
word following the instruction word is an indirect pointer to 
the operand descriptor for the kth operand; otherwise, that 
word is the operand descriptor. The ALM coding mnemonic for 
this flag is "id". 

The register number for R-type modification (if any) of 
ADDRESS of the operand descriptor. These modifications are 
similar to R-type modifications for basic instructions and are 
summarized in Table 4-1. Illegal modifiers have the entry 
"IPR" and cause an illegal procedure fault. 



Table 4-1. R-type Modifiers for REG Fields 



Octal 






Meaning as used in: 








Code 


R-type 




Indirect operand 


C(operand 






MF.REG 


descriptor -pointer 


descriptor ) 02 35 


00 


n 


n 


n 


IPR 


01 


au 


au 


au 


au 


02 


qu 


qu 


qu 


Q u , v 


03 


du 


IPR 


IPR 


dV a > 


04 
05 


ic 
al 


l *h 


ic 
al 


a (c) 


06 


ql 


q (c) 


ql 


q (c) 


07 


dl 


IPR 


IPR 


IPR 


10 


xO 


xO 


xO 


xO 


11 


x1 


x1 


x1 


xl 


12 


x2 


x2 


x2 


x2 


13 


x3 


x3 


x3 


x3 


14 


x4 


x4 


x4 


x4 


15 


x5 


x5 


x5 


x5 


16 


x6 


x6 


x6 


x6 


17 


x7 


x7 


x7 


x7 


I 











(a) The du modifier is permitted only in the second operand descriptor of the 
scd, scdr, scm, and scmr instructions to specify that the test 
character(s) reside(s) in bits 0-18 of the operand descriptor. 

(b) The ic modifier is permitted in MFk. REG and C(od)o 2 ^ only if 
MFk.RL = 0, that is, if the contents of the register is an address 
offset, not the designation of a register containing the operand 
length. 
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c) The limit of addressing extent of the processor is 2**18 words; that is, 
given an address, y, a modifier may be employed to access a main memory 
word anywhere in the range (y-2**17, y+2**17-1), provided other address 
range constraints are not violated. Since it is desirable to address this 
same extent as words, characters, and bits it is necessary to provide a 
register with range greater than the 12 bits of N or the 18 bits of normal 
R-type modifiers. This is done by extending the range of the A and Q 
modifiers as follows: 



Mode 


Range 


A,Q bits 


9-bit 


21 


15,35 


6-bit 


21 


15,35 


1-bit 


22 


14,35 


bit 


24 


12,35 



The unused high-order bits are ignored. 



MF CODING EXAMPLES 

a.m A i X of ^ the EIS instruction descriptions in this section give examples of 
ALM coding formats. For example, the mlr instruction shows: 

mlr ( MF 1>>(MF2)[,fill(octalexpression)][,enablefault] 
descna Y-charn 1 [ (CN1 ) ] , N1 h = 4, 6, or 9 (TA1 =2 1 or 0) 
descna Y-charn2[ (CN2) ] ,N2 n = 4, 6, or 9 (TA2 =2, l| or 0) 

where MF 1 and MF2 represent the EIS Modifier Fields for the first and second 
data descriptors, respectively. 

The meanings of the various codes in an MF field are: 

If C(MFn) 

Contains It Means 

pr Y-charn is not the memory address of the data but is a 

reference to a pointer register pointing to the data. 

id Tne data in descn is not the data descriptor but is the 

memory address (or pointer register reference) of the data 
descriptor. 

rl Tne field Nn is not the data length but is the code for 

register containing the data length (see Table 4-1). 

EIS Operand Descriptors and Indirect Pointers 

The words following an EIS multiword instruction word are either operand 
descriptors or indirect pointers to the operand descriptors. The interpretation of 
the words is performed according to the settings of the control bits in the associated 
modification field (MF). The kth word following the instruction word is interpreted 
according to the contents of MFk. See EIS modification fields (MF) above for meaning 
of the various control bits. See Section 2 and Section 6 for further details. 
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OPERAND DESCRIPTOR INDIRECT POINTER FORMAT 

If MFk.ID = 1, then the kth word following an EIS multiword instruction word 
is not an operand descriptor , but is an indirect pointer to an operand descriptor 
and is interpreted as shown in Figure 1-5. 









1 
7 


1 2 
A 8 


2 

9 


3 3 
1 


3 3 
2 5 


ADDRESS 


oooooooooco 


A 





REG 






13 


11 


1 


2 


1 



Figure 4-5. Operand Descriptor Indirect Pointer Format 



ADDRESS The given address of the operand descriptor . This address may 

be: 

An 18-bit absolute main memory address if A = (absolute 
mode only) 

An 18-bit offset relative to the base address register 
(BAR) if A = C (BAR mode only) 

An 16-bit offset relative to the base of the current 
procedure segment if A = (appending mode only) 

A 3-bit pointer register number (n) and a 15-bit offset 
relative to C ( PRn .WORDNO) if A = 1 (all modes) 

A Indirect via pointer register flag. This flap controls 

interpretation of the ADDRESS field of the indirect 
pointer just as the "A" flag controls interpretation of 
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REG 



the ADDRESS field of the basic and EIS single-word 
instructions. 

Address modifier for ADDRESS. All register modifiers except 
du and dl may be used. If the ic modifier is used, then 
ADDRESS is an 18-bit offset relative to value of the 
instruction counter for the instruction word . C(REG) is 
always interpreted as a word offset. 



Machine words in this format are generated by the ALM arg pseudo-instruction 
giving an appropriate TAG field. 



ALPHANUMERIC OPERAND DESCRIPTOR FORMAT 

c ° r any operand of an EIS multiword instruction that requires alphanumeric 
data, the operand descriptor is interpreted as shown in Figure 4-6. 





Q 




1 
7 


1 2 

? 


2 2 

1 2 


2 


*•> 

4 




7 
5 


ADDRESS 


CM 


TA 





N 




i 


IP, 


3 


2 


1 






12 



Figure 4-6. Alphanumeric Operand Descriptor Format 



ADDRESS 



CN 



The given address of the operand. 
(for the kth operand): 



This address mav be 



a.n 1 Q -bit absolute main memory address if MFk.AP= 
(absolute mode only) 

An 18-bit offset relative to the base address register 
if MFk.AR = (BAR mode only) 

An iS-bit offset relative to the base of the current 
procedure segment if MFk.AR = (appending mode only) 

A 3-bit address register number (n) and a 15-bit word 
offset relative to C(ARn) if MFk.AR = 1 (all modes) 

Character number. This field gives the character position 
relative to ADDRESS of the first operand character. Its 
interpretation depends on the data type (see TA below) of 
the operand. Table 4-2 below shows the interpretation of 
the field. A digit In the table indicates the corresponding 
character position (see Section 2 for data formats) and an 
"x" indicates an invalid code for the data type. Invalid 
codes cause illegal procedure faults. (For further 
explanation, see the Note under ARruBITNO. in Section 3, 
"Address Registers".) 
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Table 4-2. Alphanumeric Character Number (CN) Codes 







Data type 




C(CN) 


4-bit 


6-bit 


9-bit 


000 











001 


1 


1 


X 


010 


2 


2 


1 


011 


3 


3 


X 


100 


4 


4 


2 


101 


5 


5 


X 


110 


6 


X 


3 


111 


7 


X 


X 



TA 



Type alphanumeric. This is the data type code for the 
operand. The interpretation of the field is shown in 
Table 4-3. The code shown as Invalid causes an illegal 
procedure fault. 



Table 4-3. Alphanumeric Data Type (TA) Codes 



C(TA) 


Data type 


00 
01 
10 
11 


9-bit 

6-bit 

4-bit 

Invalid 



Operand length. If MFk.RL = 0, this field contains the 
string length of the operand. If MFk.RL = 1, this field 
contains the code for a register holding the operand 

?«^ ng w length- See Table 4_1 and EIS modification fields 
IMF) above for a discussion of register codes. 



Machine words of this format 



h..„u» a % , ? ZniS Tormat are generated by ALM when processing the 
desc4a, desc6a, and desc9a pseudo-instructions. 



NUMERIC OPERAND DESCRIPTOR FORMAT 

For any operand of an EIS multiword instruction that requires numeric data 
the operand descriptor is interpreted as shown in Figure 4-7? numeric data, 
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JL 



ADDRESS 



11 2 2 2 2 2 

T » " 1 ? 3 4 



Tff 



CN 



3 1 



SF 



2 3 



Figure 4-7. Numeric Operand Descriptor Format 



key 



ADDRESS 



CN 



a TN 



The given address of the operand. This address may be 
(for the kth operand): 

An 1 8-bit absolute main memory address if MFk.AR= 
(absolute mode only) 

An 18-bit offset relative to the base address register 
if MFk.AR = (BAR mode only) 

An 18-bit offset relative to the base of the current 
procedure segment if MFk.AR = (appending mode only) 

A 3-bit address register number (n) and a 15-bit word 
offset relative to C(ARn) if MFk.AR = 1 (all modes) 

Character number. This field gives the character position 
relative to ADDRESS of the first operand digit. Its 
interpretation depends on the data type (see TN below) of 
the operand. Table 4-2 above shows the interpretation of 
the field. (For further information, see the Note under 
ARn.BITNO in Section 3 on Address Registers.) 

Type numeric. This is the data type code for the operand. 
The codes are: 



C(TN) 



1 



Data type 

9-bit 
4-bit 



Sign and decimal type of data, 
field is shown in Table 4-4. 



The interpretation of the 



Table 4-4. Sign and Decimal Type (S) Codes 



SF 



C(S) 



00 
01 
10 

11 



Sign and decimal type 



Floating-point, leading sign 
Scaled fixed-point, leading sign 
Scaled fixed-point, trailing sign 
Scaled fixed-point, unsigned 



Scaling factor. This field contains the two's complement 
value of the base 10 scaling factor; that is, the value of 
m for numbers represented as n x 10««m. The decimal point 
Is assumed to the right of the least significant digit of 
n. Negative values move the decimal point to the left; 
positive values, to the right. The range of m is (-32,31). 
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N Operand length. If MFk.RL = 0, this field contains the 

operand length in digits. If MFk.RL = 1 , it contains the 
REG code for the register holding the operand length and 
C(REG) is treated as a modulo 64 number. See Table 4-1 
and EIS modification fields (MF) above for a discussion of 
register codes. 

Machine words in this format are generated by ALM when processing the desc4fl, 
desc4ls, desc4ts, desc4ns, desc9fl, desc91s, desc9ts, and desc9ns 
pseudo- instruct ions. 



BIT-STRING OPERAND DESCRIPTOR FORMAT 

For any operand of an EIS multiword instruction that requires bit-string 
data, the operand descriptor is interpreted as shown in Figure 4-8. 





Q 




1 

7 


1 1 
8 9 


2 2 

? 


2 
4 




3 
■5 


ADDRESS 


c 


B 


N 






18 


2 


4 






12 



Figure 4-8. Bit String Operand Descriptor Format 



ADDRESS The given address of the operand. This address may be 
(for the kth operand): 

An 18-bit main memory address if MFk.AR= (absolute 
mode only) 

An 1 8-bit offset relative to the base address register 
if MFk.AR = (BAR mode only) 

An 18-bit offset relative to the base of the current 
procedure segment if MFk.AR = (appending mode only) 

A 3-bit address register number (n) and a 15-bit word 
offset relative to C(ARn) if MFk.AR = 1 (all modes) 

C The character number of the 9-bit character relative to 

ADDRESS containing the first bit of the operand. (For 
further explanation, see the Note under ARnBITNO in Section 
3 on Address Registers.) 



B 
N 



The bit number within the 9-bit character, C, of the first 
bit of the operand. 

Operand length. If MFk.RL = 0, this field contains the 
string length of the operand. If MFk.RL = 1, this field 
contains the code for a register holding the operand string 
length. See Table 4-1 and EIS modification fields (MF) 
above for a discussion of register codes. 



Machine words of this format are generated by ALM when processing the descb 
pseudo- instruct ion. 



2/82 



4-15 



AL39B 



FIXED-POINT DATA MOVEMENT LOAD 



FIXED-POINT ARITHMETIC INSTRUCTIONS 



Fixed-Point Data Movement Load 



eaa 



Effective Address to A 



635 (0) 



FORMAT: 
SUMMARY 



Basic instruction format (see Figure J4-1), 

C(TPR.CA) -> C(A) Q 17 
00. ..0 -> C(A) 1g> 35 



MODIFICATIONS: AH except du, dl 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 
Negative 



NOTES: 



If C(A) = 0, then ON; otherwise OFF 
If C(A) = 1, then ON; otherwise OFF 

The eaa instruction, and the instructions eaq and eaxn, 
facilitate interregister data movements. The data source 
is specified by the address modification, and the data 
destination by the operation code of the instruction. 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



eaq 



Effective Address to Q 



636 (0) 



FORMAT: 



SUMMARY 



Basic instruction format (see Figure 4-1) 

C(TPR.CA) -> C(Q) 017 
00. ..0 -> C(Q) 18j35 



MODIFICATIONS: All except du, dl 



4-16 



AL39 



FIXED-POINT DATA MOVEMENT LOAD 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Q) = 0, then ON; otherwise OFF 
Negative If C(Q) = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



eaxn 



Effective Address to Index Register n 



52n (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure M-1). 

For n = 0, 1, . . . , or 7 as determined by operation code 
C(TPR.CA) -> C(Xn) 



MODIFICATIONS: All except du, dl 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Xn) = 0, then ON; otherwise OFF 
Negative If C(Xn) = 1, then ON; otherwise OFF 



NOTES : 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



lea 



Load Complement A 



335 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



-C(Y) -> .C(A) 



MODIFICATIONS: All 
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FIXED-POINT DATA MOVEMENT LOAD 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Overflow 



NOTES: 



If C(A) = 0, then ON; otherwise OFF 
If C(A) = 1, then ON; otherwise OFF 
If range of A is exceeded, then ON 

The lea instruction changes the number to its negative 
while moving it from Y to A. The operation is executed by 
forming the twos complement of the string of 36 bits. In 
twos complement arithmetic, the value is its own 
negative. An overflow condition exists if C(Y) = -2**35. 



lcaq 



Load Complement AQ 



337 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



-C(Y-pair) -> C(AQ) 



MODIFICATIONS: 



All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(AQ) = 0, then ON; otherwise OFF 
Negative If C(AQ) = 1, then ON-; otherwise OFF 
Overflow If range of AQ is exceeded, then ON 



NOTES: 



The lcaq instruction changes the number to its negative 
while moving it from Y-pair to AQ. The operation is 
executed by forming the twos complement of the string of 
72 bits. In twos complement arithmetic, the value is 
its own negative. An overflow condition exists if 
C(Y-pair) = -2**71. 



lcq 



Load Complement Q 



336 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



-C(Y) -> C(Q) 



MODIFICATIONS: All 
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FIXED-POINT DATA MOVEMENT LOAD 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Q) = 0, then ON; otherwise OFF 
Negative If C(Q) Q = 1, then ON; otherwise OFF 
Overflow If range of Q is exceeded, then ON 



NOTES: 



The lcq instruction changes the number to its negative 
while moving it from Y to Q. The operation is executed by 
forming the twos complement of the string of 36 bits. In 
twos complement arithmetic, the value is its own 
negative. An overflow condition exists if C(Y) = -2**35. 



lcxn 



Load Complement Index Register n 



32n (0) 



FORMAT: 
SUMMARY: 

MODIFICATIONS: 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, . .., or 7 as determined by operation code 
-C(Y) 0>17 -> C(Xn) 

All except ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Xn) = 0, then ON; otherwise OFF 
Negative If C(Xn) Q = 1, then ON; otherwise OFF 
Overflow If range of Xn is exceeded, then ON 



NOTES: 



The lcxn instruction changes the number to its negative 



while moving it from Y f 



to Xn. The operation is 



executed by forming the twos complement of the string of 

18 bits. In twos complement arithmetic, the value is 

its own negative. An overflow condition exists if 
C(Y) 0j1? = -2**17. 

Attempted repetition with the rpl instruction and with the 
same register given as target and modifier causes an 
illegal procedure fault. 



Ida 



Load A 



235 CO) 



FORMAT: 



Basic instruction format (see Figure 4-1) 
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FIXED-POINT DATA MOVEMENT LOAD 



SUMMARY: 



C(Y) -> C(A) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 
Negative If C(A) = 1, then ON; otherwise OFF 



ldac 



Load A and Clear 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

C(Y) -> C(A) 
00... -> C(Y) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 

Zero 
Negative 

NOTES : 



034 (0) 



(Indicators not listed are not affected) 

If C(A) = 0, then ON; otherwise OFF 
If C(A) = 1, then ON, otherwise OFF 



The ldac instruction causes a special main memory 
reference that performs the load and clear in one cycle. 
Thus, this instruction can be used in locking data. 



ldaq 



Load AQ 



237 (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(Y-pair) -> C(AQ) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



Zero 
Negative 



(Indicators not listed are not affected) 

If C(AQ) = 0, then ON; otherwise OFF 
If C(AQ) = 1, then ON; otherwise OFF 
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FIXED-POINT DATA MOVEMENT LOAD 



ldi 



Load Indicator Register 



634 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: C(Y) 18,31 _> C < IR > 
MODIFICATIONS: All except ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Parity 
mask 



Not BAR 
mode 



If C(Y)27 = 1f and the processor is in absolute or 
privileged mode, then ON; otherwise' OFF. This indicator 
is not affected in the normal or BAR modes. 

Cannot be changed by the ldi instruction 



NOTES: 



Mid If C(Y)o = 1, and the processor is in absolute or 
instruction privileged mode, then ON; otherwise OFF. This indicator 
interrupt is not affected in normal or BAR modes, 
fault 

Absolute Cannot be changed by the ldi instruction 
mode 

All other If corresponding bit in C(Y) is 1, then ON; otherwise, OFF 
indicators 

The relation between C(Y)ig ^ and the indicators is given 
in Table 4-5 below. ,J 

The tally runout indicator reflects C(Y)25 re Sa rd less °f 
what address modification is performeor on the ldi 
instruction. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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FIXED-POINT DATA MOVEMENT LOAD 



Table 4-5. Relation Between Data Bits and Indicators 



Bit 






Position C(Y) 


Indicator 




18 


Zero 




19 


Negative 




20 


Carry 




21 


Overflow 




22 


Exponent overflow 




23 


Exponent underflow 




24 


Overflow mask 




.25 


Tally runout 




26 


Parity error 




27 


Parity mask 




.28 


Not BAR mode 




29 


Truncation 




30 


Mid instruction interrupt 


fault 


31 


Absolute mode 





ldq 



Load Q 



236 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(Y) -> C(Q) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Q) = 0, then ON; otherwise OFF 
Negative If C(Q) = 1, then ON; otherwise OFF 



ldqc 



Load Q and Clear 



032 (0) 



FORMAT: 



Basic instruction format (see Figure 4-T) 



SUMMARY: 



C(Y) -> C(Q) 
00. ..0 -> C(Y) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



4-22 



AL39 



FIXED-POINT DATA MOVEMENT LOAD 



INDICATORS: 

Zero 
Negative 

NOTES: 



(Indicators not listed are not affected) 

If C(Y) = 0, then ON; otherwise OFF 
If C(Y) = 1, then ON, otherwise OFF 

The ldqc instruction causes a special main memory 
reference that performs the load and clear in one cycle. 
Thus, this instruction can be used in locking data. 



ldxn 



Load Index Register n 



22n (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: For n = 0, 1, . . . , or 7 as determined by operation code 

C(Y) 1? -> C(Xn) 

MODIFICATIONS: All except ci, sc, scr 



INDICATORS: 

Zero 
Negative 

NOTES: 



(Indicators not listed are not affected) 

If C(Xn) = 0, then ON; otherwise OFF 
If C(Xn) = 1, then ON; otherwise OFF 



Attempted repetition with the rpl instruction with the 
same register given as target and modifier causes an 
illegal procedure fault. 



lreg 



Load Registers 



FORMAT: 
SUMMARY: 



073 (0) 



Basic instruction format (see Figure 4-1). 



C(Y-block8) 0)17 -> C(X0) 
C(Y-block8+1) 017 -> C(X2) 
C(Y-bloek8+2) 0>17 -> C(X4) 

C(Y-block8+3) 0> i 7 _> c(x6) 
C(Y-block8+4) -> C(A) 
C(Y-block8+6) ? -> C(E) 



C(Y-block8) 18>35 -> C(X1) 
C(Y-block8+1) l8 35 -> C(X3) 
C(Y-block8+2) 18>35 -> C(X5) 
C(Y-block8+3) 18)3 5 -> C(X7) 
C(Y-block8+5) -> C(Q) 
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FIXED-POINT DATA MOVEMENT LOAD 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



All except du, dl, ci, sc, scr 



None affected 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or rpl 



lxln 



Load Index Register n from Lower 



- 72n (0) 



FORMAT: 



Basic instruction fbrmat (see Figure. 4-1) 



SUMMARY: For n = 0, 1, — , or 7 as determined by operation code 

C(Y) 18}35 -> C(Xn) 

MODIFICATIONS: All except ci, sc, scr 



INDICATORS: 



Zero 
Negative 



NOTES: 



(Indicators not listed are not affected) 

If C(Xn) = 0, then ON; otherwise OFF 
If C(Xn) = 1, then ON; otherwise OFF 



Attempted repetition with the rpl instruction with the 
same register given as target and modifier causes an 
illegal procedure fault. 
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FIXED-POINT DATA MOVEMENT STORE 



Fixed-Point Data Movement Store 



sreg 



Store Registers 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 



INDICATORS: 



NOTES: 



753 (0) 



] 



Basic instruction format (see Figure 4-1). 



C(X0) -> C(Y-block8) 0j17 
C(X2) -> C(Y-block8+1) 0> 17 
C(X6) -> C(Y-block8+3) 0> 17 
C(A) -> C(Y-block8+4) 
C(E) -> C(Y-block8+6) 0>7 
C(TR) -> C(Y-block8+7) 0>2 6 



C(X1) -> C(Y-block8) l8j35 
C(X3) -> C(Y-block8+1) l8)35 
C(X7) -> C(Y-block8+3) 1 g > 35 
C(Q) -> C(Y-block8+5) 
00. .-0 -> C(Y-block8+6) 8)35 
00... -> C(Y-block8+7) 2 7 ) 32 



C(RALR) -> C(Y-block8+7)3 3> 35 
All except du, dl, ci, so, scr 
None affected 



Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 
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FIXED-POINT DATA MOVEMENT STORE 



sta 



Store A 



755 (0) 



FORMAT: 



Basic instruction format (see Figure 1-1) 



SUMMARY: 



C(A) -> C(Y) 



MODIFICATIONS: All except du, dl 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



stac 



Store A Conditional 



354 ( 



H 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



If C(Y) = 0, then C(A) -> C(Y) 



MODIFICATIONS: All except du, dl , ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 



If initial C(Y) = 0, then ON; otherwise OFF 



NOTES: 



If the initial C(Y) is nonzero, then C(Y) is not changed 
by the stac instruction. 

The stac instruction uses a special main memory reference 
that prohibits such references by other processors between 
the test and the data transfer. Thus, it may be used for 
data locking. 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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stacq 



Store A Conditional on Q 



654 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1), 



SUMMARY: 



If C(Y) = C(Q), then C(A) -> C(Y) 



MODIFICATIONS: All except du, dl, ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If initial C(Y) = C(Q), then ON; otherwise OFF 

NOTES: If the initial C(Y) is i C(Q), then C(Y) is not changed by 

the stacq instruction. 

The stacq instruction uses a special main memory reference 
that prohibits such references by other processors between 
the test and the data transfer. Thus, it may be used for 
shared data locking and unlocking. 

On the DPS 8M processor, data shared by more than one 
processor may, at any time, be in more than one processor's 
cache memory. To aid the integrity of shared data, the 
stacq instruction will always bypass cache and obtain its 
operand from main memory. In addition, a synchronizing 
function inhibits completion of the stacq instruction until 
the processor executing the stacq instruction is notified 
by the scu that write completes have occurred and write 
notifications requesting cache block clears have been sent 
to the other processors for all write instructions that 
the processor previously issued. This feature, therefore, 
makes the stacq instruction the preferred choice for unlocking 
shared data bases. 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



staq 



Store AQ 



757 (0) 



FORMAT: 

SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

NOTES: 



Basic instruction format (see Figure 4-1). 

C(AQ) -> C(Y-pair) 

All except du, dl, ci, sc, scr 

None affected 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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FIXED-POINT DATA MOVEMENT STORE 



stba 



Store Bytes of A 



55K0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



9-bit bytes of C(A) -> corresponding bytes of C(Y), the 
byte positions affected being specified in the TAG field. 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



None (see NOTES below) 



None affected 



Binary ones in the TAG field of this instruction specify 
the byte positions of A and Y that are affected. The 
control relations are shown in Table 4-6. 

ALM treats a given numeric TAG field for this instruction 
as an octal number. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



Table 4-6. Control Relations for Store Byte Instructions (9-Bit) 



Bit position 
within TAG field 


Bit of 
instruction 


Byte 
of A and Y 





30 


Byte 
(bits 0-8) 


1 


31 


Byte 1 
(bits 9-17) 


2 


32 


Byte 2 
(bits 18-26) 


3 


33 


Byte 3 
(bits 27-35) 
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FIXED-POINT DATA MOVEMENT STORE 



stbq 



Store Bytes of Q 



552 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 



9-bit bytes of C(Q) -> corresponding bytes of C(Y), the 
byte positions affected being specified in the TAG field. 



MODIFICATIONS: 

INDICATORS:" 

NOTES: 



None (see NOTES below) 



None affected 



Binary ones in the TAG field of this instruction specify 
the byte positions of Q and Y that are affected. The 
control relations are shown in Table 4-6 above. 

ALM treats a given numeric TAG field for this instruction 
as an octal number. 



Attempted repetition . with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 



std 



Store Instruction Counter Plus 1 



554 (0) 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



Basic instruction format (see Figure 4-1) 

C(PPR.IC) + 1 -> C(Y). 17 
C(IR) -> C(Y) 18>31 
00. .,0 -> C(Y) 3 2 f 35 

All except du, dl, ci, sc, scr 

None affected 



The contents of the instruction counter C(PPR.IC) and the 
indicator register (IR) after address preparation are 
stored in C(Y) 17 and C(Y) 1 o 31 , respectively. C(Y)?k 
reflects the state of the tally runout indicate - ----- fr - 

modification. The 

indicators are given in Table 4-5. 



;or prior to 
relations between C(Y)io ^-i and the 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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stc2 



Store Instruction Counter Plus 2 



750 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: CCPPR.ICl + 2 -> C(Y) 17 
MODIFICATIONS: All except du, dl , ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



The contents of the instruction counter C(PPR.IC) are 
stored in C(Y) 17 . 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



stca 



Store Characters of A 



FORMAT: 
SUMMARY: 



751 (0) 



Basic instruction format (see Figure 4-1) 



Characters of C(A) -> corresponding characters of C(Y) , 
the character positions affected being specified in the 
TAG field. 



MODIFICATIONS: 

INDICATORS: 

MOTES: 



None (see NOTES below) 



None affected 



Binary ones in the TAG field of this instruction specify 
character positions of A and Y that are affected. The 
control relations are shown in Table 4-7. 

ALM treats a given numeric TAG field for this instruction 
as an octal number. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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Table 4-7. Control Relations for Store Character Instructions (6-Bit) 



Bit position 
within TAG field 


Bit of 
instruction 


Character 
of A and Y 





30 


Char 
(bits 0-5) 


1 


31 


Char 1 
(bits 6-11) 


2 


32 


Char 2 
(bits 12-17) 


3 


33 


Char 3 
(bits 18-23) 


4 


34 


Char 4 
(bits- 24-29) 


5 


35 


Char 5 
(bits 30-35) 



stcq 



Store Characters of Q 



752 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1) 



Characters of C(Q) -> corresponding characters of C(Y) , 
the character positions affected being specified by the 
TAG field. 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



None (see NOTES below) 



None affected 



Binary ones in the TAG field of this instruction specify 
the character positions of Q and Y that are affected. The 
control relations are shown in Table 4-7 above. 

ALM treats a given numeric TAG field for this instruction 
as an octal number. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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stcd 



Store Control Double 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



357 CO) " 



Basic instruction format (see Figure 4-1) 

C(PPR) -> C(Y-pair) as follows: 
000 -> C(Y-pair) Q 2 
C(PPR.PSR) -> C(Y-pair) 3 1? 
C(PPR.PRR) -> C(Y-pair) l8 2Q 
00... -> C(Y-pair) 21 2g 
(43) 8 -> C(Y-pair) 30>35 
C(PPR.IC)+2 -> C(Y-pair) 36 5J 
00... -> C(Y-pair) 54 ?1 

All except du f dl, ci, sc, scr 

None affected 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



sti 



Store Indicator Register 



FORMAT: 
SUMMARY: 



INDICATORS: 



754 (0) 



: 



Basic instruction format (see Figure 4-1) 

C(IR) -> C(T) l8f31 
00... -> C(Y) 32 35 



MODIFICATIONS: All except du, dl f ci, sc, scr 



None affected 



NOTES: 



The contents of the indicator register after address 
preparation are stored in C(Y) 18 „. C(Y) 18 ., reflects 
the state of the tally runout indicator prior- 5 to address 
preparation. The relation between C(Y)-,o ,-, and the 
indicators is given in Table 4-5. °' JI 
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Attempted repetition with . the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



stq 



Store Q 



756 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(Q) -> C(Y) 



MODIFICATIONS: All except du, dl 



INDICATORS; 



None affected 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



stt 



Store Time Register 



454 CO) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(TR) -> C(Y) 0>2 6 
00... -> C(Y)27 >3 5 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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stxn 



Store Index Register n 



74n (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: For n =0, 1, . . . , or 7 as determined by operation code 

C(Xn) -> C(Y) 0j17 

MODIFICATIONS: All except du, dl, ci, sc, scr 

INDICATORS:. None affected 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



stz 



Store Zero 



450 (0) 



FORMAT: Basic instruction format (see Figure 4-1) 



SUMMARY: 



00... -> C(Y) 



MODIFICATIONS: All except du, dl 



INDICATORS: None affected 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



sxln 



Store Index Register n in Lower 



44n (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



For n = 0, 1, . . . , or 7 as determined by operation code 
C(Xn) -> C(Y) 18 35 



4-34 



AL39 



FIXED-POINT DATA MOVEMENT STORE 



MODIFICATIONS: All except du, dl, ci, sc, scr 

INDICATORS: None affected 

NOTES: Attempted repetition with the rpl instruction causes an 

illegal procedure fault. 
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Fixed-Point Data Movement Shift 



air 



A Left Rotate 



FORMAT: 



775 (0) 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



Shift CCA) left the number of positions given in 
C(TPR.CA)'ii ,17^ entering each bit leaving A Q into A 35 . 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 
Negative If C(A) Q = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



als 



A Left Shift 



735 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



Shift C(A) left the number of positions given in by 
CCTPR.CA)^ -|y; filling vacated positions with zeros. 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 

Negative If C(A) = 1, then ON; otherwise OFF 

Carry If C(A) changes during the shift, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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arl 



A Right Logical 



771 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



Shift C(A) right the number of positions given in 
C(TPR.CA)^ 17; filling vacated positions with zeros. 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 
Negative If C(A) = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



ars 



A Right Shift 



731 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



Shift C(A) right the number of positions given in 
C(TPR.CA) 11 17 ; filling vacated positions with initial 
C(A) . "*" 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 
Negative If C(A) = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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llr 



Long Left Rotate 



777 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



Shift C(AQ) left by the number of positions given in 
CCTPR.CA)^ jy.; entering each bit leaving AQ Q into AQ 71 . 



MODIFICATIONS: All except du, dl, ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(AQ) = 0, then ON; otherwise OFF 
Negative If C(AQ) Q = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



lis 



Long Left Shift 



737 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



Shift C(AQ) left the number of positions given in 
CfTPR.CA)^ 17 ; filling vacated positions with zeros. 



MODIFICATIONS: All except du, dl , ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(AQ) = 0, then ON; otherwise OFF 

Negative If C(AQ) = 1, then ON; otherwise OFF 

Carry If C(AQ) changes during the shift, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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Irl 



Long Right Logical 



773 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: Shift C(AQ) right the number of positions given in 
C(TPR.CA) 11 f 17; filling vacated positions with zeros. 

MODIFICATIONS: All except du, dl, ci , sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(AQ) = 0, then ON; otherwise OFF 
Negative If C(AQ) = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



Irs 



Long Right Shift 



733 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



Shift C(AQ) right the number of positions given in 
C(TPR.CA) 11 17 ; filling vacated positions with initial 
C(AQ) n . "'" 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 
Negative 



NOTES: 



If C(AQ) = 0, then ON; otherwise OFF 
If C(AQ) = 1, then ON; otherwise OFF 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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qlr 



Q Left Rotate 



FORMAT: 



776 (0) 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



MODIFICATIONS: 



Shift C(Q) left the number of positions given in 
C(TPR.CA) 11>17 ; entering each bit leaving Q into Q 35 . 

All except du, dl, ci, sc, scr 



INDICATORS: (Indicators not listed are not affected) 

Zero If C(Q) = 0, then ON; otherwise OFF 
Negative If C(Q) = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an" 
illegal procedure fault. 



qls 



Q Left Shift 



736 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



Shift C(Q) left the number of positions given in 
C(TPR.CA) 11 ^ 17 ; fill vacated positions with zeros. 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected.) 



Zero If C(Q) = 0, then ON; otherwise OFF 

Negative If C(Q) Q = 1, then ON; otherwise OFF 

Carry If C(Q) changes during the shift, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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qrl 



Q Right Logical 



772 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: Shift C(Q) right the number of positions specified by 

Y 11,17» fill vacated positions with zeros. | 

MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Q) = 0, then ON; otherwise OFF 
Negative If C(Q) = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



qrs 



Q Right Shift 



732 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



Shift C(Q) right the number of positions given in 
C(TPR.CA) 11 17 ; filling vacated positions with initial 
C(Q) . 



MODIFICATIONS: All except du, dl , ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Q) s 0, then ON; otherwise OFF 
Negative If C(Q) = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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Fixed-Point Addition 



ada 



Add to A 



075 (0) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: C (A) + C(Y) -> C(A) 
MODIFICATIONS: All 



INDICATORS: 

Zero 

Negative 
Overflow 
Carry 



(Indicators not listed are not affected) 

If C(A) = 0, then ON; otherwise OFF 

If C(A) = 1, then ON; otherwise OFF 

If range of A is exceeded, then ON 

If a carry out of A Q is generated, then ON; otherwise OFF 



adaq 



Add to AQ 



077 (0) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: C(AQ) + C(Y-pair) -> C(AQ) 



MODIFICATIONS: 

INDICATORS: 

Zero 

Negative 
Overflow 
Carry 



All except du, dl, ci, sc, scr 

(Indicators not listed are not affected) 

If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If range of AQ is exceeded, then ON 

If a carry out of AQ is generated,- then ON; otherwise OFF 
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adl 



Add Low to AQ 



033 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(AQ) + C(Y) sign extended -> C(AQ) 



MODIFICATIONS: All except ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 
Overflow 
Carry 



NOTES : 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If range of AQ is exceeded, then ON 

If a carry out of AQ is generated, then ON; otherwise OFF 

A 72-bit number is formed from C(Y) in the following 
manner : 

The lower 36 bits (36,71) are identical to C(Y). 

Each of the upper 36 bits (0,35) is identical to C(Y)0. 

This 72-bit .number is added to the contents of the 
combined AQ-register. 



adla 



Add Logical to A 



035 (0) 



FORMAT: 



Basic instruction' format (see Figure 4-1) 



SUMMARY: 



C(A) + C(Y) -> C(A) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 

Negative If C(A) = 1, then ON; otherwise OFF 

Carry If a carry out of A Q is generated, then ON; otherwise OFF 



NOTES: 



The adla instruction is identical to the ada instruction 
with the exception that the overflow indicator is not 
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affected by the adla instruction, nor does an overflow 
fault occur. Operands and results are treated as 
unsigned, positive binary integers. 



adlaq 



Add Logical to AQ 



FORMAT: 

SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

Zero 

Negative 

Carry 

NOTES: 



037 (0) 



Basic instruction format (see Figure 4-1). 

C(AQ) + C(Y-pair) ^> C(AQ) 

All except du, dl, ci, sc, scr 

(Indicators not listed are not affected) 

If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If a carry out of AQ is generated, then ON; otherwise OFF 

The adlaq instruction is identical to the adaq instruction 
with the exception that the overflow indicator is not 
affected by the adlaq instruction, nor does an overflow 
fault occur. Operands and results are treated as 
unsigned, positive binary integers. 



adlq 



Add Logical to Q 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(Q) + C(Y) -> C(Q) 



036 (0) 



MODIFICATIONS: 
INDICATORS: 



All 



(Indicators not listed are not affected) 



Zero If C(Q) = 0, then ON; otherwise OFF 

Negative If C(Q) = 1, then ON; otherwise OFF 

Carry If a carry out of Q is generated, then ON; otherwise OFF 

NOTES: The adlq instruction is identical to the adq instruction 

with the exception that the overflow indicator is not 
affected by the adlq instruction, nor does an overflow 
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fault occur. Operands and results are treated as 
unsigned, positive binary integers. 



adlxn 



Add Logical to Index Register n 



02n (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, . . . , or 7 as determined by operation code 
C(Xn) + C(Y) 017 -> C(Xn) 



MODIFICATIONS: All except ci, sc, scr 



INDICATORS: 

Zero 

Negative 

Carry 

NOTES: 



(Indicators not listed are not affected) 

If C(Xn) = 0, then ON; otherwise OFF 

If C(Xn) = 1, then ON; otherwise OFF 

If a carry out of Xn Q is generated, then ON; otherwise OFF 

The adlxn instruction is identical to the adxn instruction 
with the exception that the overflow indicator is not 
affected by the adlxn instruction, nor does an overflow 
fault occur. Operands and results are treated as 
unsigned, positive binary integers. 



adq 



Add to Q 



076 (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(Q) + C(Y) -> C(Q) 



MODIFICATIONS: All 



INDICATORS: 

Zero 

Negative 
Overflow 
Carry 



(Indicators not listed are not affected) 

If C(Q) = 0, then ON; otherwise OFF 

If C(Q) = 1, then ON; otherwise OFF 

If range of Q is exceeded, then ON 

If a carry out of Qq is generated, then ON; otherwise OFF 



4-45 



AL39 



FIXED-POINT ADDITION 



adxn 



Add to Index Register n 



06n (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: For n s 0, 1, . . . , or 7 as determined by operation code 

C(Xn) + C(Y) 017 -> C(Xn) 

MODIFICATIONS: All except. ci, sc, scr 



INDICATORS: 



Zero 

Negative 
Overflow 
Carry 



(Indicators not listed are not affected) 

If C(Xn) = 0, then ON; otherwise OFF 

If C(Xn) = 1, then ON; otherwise OFF 

If range of Xn is exceeded, then ON 

If a carry out of Xn Q is generated, then ON; otherwise OFF 



aos 



Add One to Storage 



054 (0) 



FORMAT: 



SUMMARY: 



INDICATORS: 

Zero 

Negative 
Overflow 
Carry 

NOTES: 



Basic instruction format (see Figure 4-1) 



C(Y) + 1 -> C(Y) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



(Indicators not listed are not affected) 

If C(Y) = 0, then ON; otherwise OFF 

If C(Y) = 1, then ON; otherwise OFF 

If range of Y is exceeded, then ON 

If a carry out of Yq is generated, then ON; otherwise OFF 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



as a 



Add Stored to A 



055 (0) 
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FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(A) + C(Y) -> CCY) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y) = 0, then ON; otherwise OFF 

Negative If C(Y) = 1, then ON; otherwise OFF 

Overflow If range of Y is exceeded, then ON 

Carry If a carry out of Yq is generated, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



asq 



Add Stored to Q 



056 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(Q) + C(Y) -> C(Y) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y) = 0, then ON; otherwise OFF 

Negative IF C(Y) = 1, then ON; otherwise OFF 

Overflow If range of Y is exceeded, then ON 

Carry If a carry out of Yq is generated, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



asxn 



Add Stored to Index Register n 



04n (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 
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SUMMARY: For n = 0, 1, . .., or 7 as determined by operation code 

C(Xn) + C(Y) 0f17 -> C(Y) 0>17 

MODIFICATIONS: All except du, dl, ci , sc, scr 



INDICATORS: 

Zero 

Negative 
Overflow 
Carry 

NOTES: 



(Indicators not listed are not affected) 

If C(Y) 0>17 = 0, then ON; otherwise OFF 

If C(Y) = 1, then ON; otherwise OFF 

If range of Y 17 is exceeded, then ON 

If a carry out of Y is generated, then ON; otherwise OFF 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



awca 



Add with Carry to A 



071 (0) 



FORMAT: 
SUMMARY: 



INDICATORS: 

Zero 

Negative 
Overflow 
Carry 

NOTES: 



Basic instruction format (see Figure 4-1). 

If carry indicator OFF, then C(A) + C(Y) -> C(A) 

If carry indicator ON, then C(A) + C(Y) + 1 -> C(A) 



MODIFICATIONS: All 



(Indicators not listed are not affected) 

If C(A) = 0, then ON; otherwise OFF 

If C(A) = 1, then ON; otherwise OFF 

If range of A is exceeded, then ON 

If a carry out of A Q is generated, then ON; otherwise OFF 

The awca instruction is identical to the ada instruction 
with the exception that when the carry indicator is ON at 
the beginning of the instruction, 1 is added to the sum of 
C(A) and C(Y). 



awcq 



Add with Carry to Q 



072 (0) 
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FORMAT: 
SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

Zero 

Negative 
Overflow 
Carry ' 

NOTES: 



Basic instruction format (see Figure 4-1). 

If carry indicator OFF, then C(Q) + C(Y) -> C(Q) 

If carry indicator ON, then C(Q) + C(Y) + 1 -> C(Q) 



All 



(Indicators not listed are not affected) 

If C(Q) = 0, then ON; otherwise OFF 

If C(Q) = 1, then ON; otherwise OFF 

If range of Q is exceeded, then ON 

If a carry out of Q is generated, then ON; otherwise OFF 

The awcq instruction is identical to the adq instruction 
with the exception that when the carry indicator is ON at 
the beginning of the instruction, 1 is added to the sum of 
C(Q) and C(Y). 
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Fixed-Point Subtraction 



sba 



Subtract from A 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



CCA) - C(Y) -> C(A) 



175 (0) 



MODIFICATIONS: All 



INDICATORS: 

Zero 

Negative 
Overflow 
Carry 



(Indicators not listed are not affected) 

If CCA)- = 0, then ON; otherwise OFF 

If C(A) = 1, then ON; otherwise OFF 

If range of A is exceeded, then ON 

If a carry out of A Q is generated, then ON; otherwise OFF 



sbaq 



Subtract from AQ 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(AQ) - C(Y-pair) -> C(AQ) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 

Zero 

Negative 
Overflow 
Carry 



177 (0) 



(Indicators not listed are not affected) 

If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If range of AQ is exceeded, then ON 

If a carry out of AQ Q is generated, then ON; otherwise OFF 



sbla 



Subtract Logical from A 



135 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 
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SUMMARY: 



C(A) - C(Y) -> C(A) 



MODIFICATIONS: 



All 



INDICATORS: 

Zero 

Negative 

Carry 

NOTES: 



(Indicators not listed are not affected) 

If C(A) = 0, then ON; otherwise OFF 

If C(A) = 1, then ON; otherwise OFF 

If a carry out of A is generated, then ON; otherwise OFF 

The sbla instruction is identical to the sba instruction 
with the exception that the overflow indicator is not 
affected by the sbla instruction, nor does an overflow 
fault occur. Operands and results are treated as 
unsigned, positive binary integers. 



sblaq 



Subtract Logical from AQ 



FORMAT: 

SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

Zero 

Negative 

Carry 

NOTES: 



137 (0) 



Basic instruction format (see Figure 4-1). 

C(AQ) - C(Y-pair) -> C(AQ) 

All except du, dl, ci, sc, scr 

(Indicators not listed are not affected) 

If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If a carry out of AQ is generated, then ON; otherwise OFF 

The sblaq instruction is identical to the sbaq instruction 
with the exception that the overflow indicator is not 
affected by the sblaq instruction, nor does an overflow 
fault occur. Operands and results are treated as 
unsigned, positive binary integers. 



sblq 



Subtract Logical from Q 



136 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 
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SUMMARY: 



C(Q) - C(Y) -> C(Q) 



MODIFICATIONS: 



All 



INDICATORS: 



(Indicators not listed are not affected) 



. Zero If C(Q) = 0, then ON; otherwise OFF 
Negative If C(Q) = 1, then ON; otherwise OFF 
Carry If a carry out of Q is generated, then ON; otherwise OFF 

NOTES: The sblq instruction is identical to the sbq instruction 

with the exception that the overflow indicator is not 
affected by the sblq instruction, nor does an overflow 
fault occur. Operands and results are treated as 
unsigned, positive binary integers. 



sblxn 



Subtract Logical from Index Register n 



12n (0) 



FORMAT: ' 
SUMMARY: 

MODIFICATIONS: 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, ..., or 7 as determined by operation code 
C(Xn) - C(Y) j ? -> C(Xn) 

All except ci, sc, ser 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Xn) = 0, then ON; otherwise OFF 

Negative If C(Xn) = 1, then ON; otherwise OFF 

Carry If a carry out of Xn Q is generated, then ON; otherwise OFF 

NOTES The sblxn instruction is identical to the sbxn instruction 

with the exception that the overflow indicator is not 
affected by the sblxn instruction, nor does an overflow 
fault occur. Operands and results are treated as 
unsigned, positive binary integers. 



sbq 



Subtract from Q 



176 (0) 



4-52 



AL39 



FIXED-POINT SUBTRACTION 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(Q) - CCY) -> C(Q) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Q) = 0, then ON; otherwise OFF 

Negative If C(Q) = 1, then ON; otherwise OFF 

Overflow If range of Q is exceeded, then ON 

Carry If a carry out of Q is generated, then ON; otherwise OFF 



sbxn 



Subtract from Index Register n 



I6n (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



For n = 0, 1, ..., or 7 as determined by operation code 
C(Xn) - C(Y) 0>17 -> C(Xn) 



MODIFICATIONS: All except ei , sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Xn) = 0, then ON; otherwise OFF 

Negative If C(Xn) = 1, then ON; otherwise OFF 

Overflow If range of Xn is exceeded, then ON 

Carry If a carry out of XnQ is generated, then ON; otherwise OFF 



ssa 



Subtract Stored from A 



155 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(A) - C(Y) -> C(Y) 



MODIFICATIONS: All except du, dl, ci, sc, scr 
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INDICATORS: 

Zero 

Negative 
Overflow 
Carry 

NOTES: 



(Indicators not listed are not affected) 

If C(Y) = 0, then ON; otherwise OFF 

If C(Y) = 1, then ON; otherwise OFF 

If range of Y is exceeded, then ON 

If a carry out of Y Q is generated, then ON; otherwise OFF 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



ssq 



Subtract Stored from Q 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(Q) - C(Y) -> C(Y) 



MODIFICATIONS: All except du, dl, ci , sc, scr 



INDICATORS: 

Zero 

Negative 
Overflow 
Carry 

NOTES: 



156 (0) 



(Indicators not listed are not affected) 

If C(Y) = 0, then ON; otherwise OFF 

If C(Y) = 1, then ON; otherwise OFF 

If range of Y is exceeded, then ON 

If a carry out of Y is generated, then ON; otherwise OFF 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



ssxn 



Subtract Stored from Index Register n 



14n (0) 



FORMAT: 



INDICATORS: 



Basic instruction format (see Figure 4-1). 



SUMMARY; For n = 0, 1, . . . , or 7 as determined by operation code 

C(Xn) - C(Y) 0>17 -> C(Y) 0f17 

MODIFICATIONS: All except du, dl , ci, sc, scr 



(Indicators not listed are not affected) 
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Zero 

Negative 
Overflow 
Carry 



NOTES: 



If C(Y) 0>17 = 0, then ON; otherwise OFF 

If C(Y) = 1, then ON; otherwise OFF 

If range of Y Q 17 exceeded, then ON 

If a carry out of Y Q is generated, then ON; otherwise OFF 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



swca 



Subtract with Carry from A 



171 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

If carry indicator ON, then C(A) - C(Y) -> C(A) 
If carry indicator OFF, then C(A) - C(Y) "- 1 -> C(A) 



MODIFICATIONS: 



All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 
Overflow 
Carry 



NOTES: 



If C(A) = 0, then ON; otherwise OFF 

If C(A) = 1, then ON; otherwise OFF 

If range of A is exceeded, then ON 

If a carry out of A Q is generated, then ON; otherwise OFF 

The swca instruction is identical to the sba instruction 
with the exception that when the carry indicator is OFF at 
the beginning of the instruction, +1 is subtracted from 
the difference of C( A) minus C(Y) . The swca instruction 
treats the carry indicator as the complement of a borrow 
indicator due to the implementation of negative numbers in 
twos complement form. 



swcq 



Subtract with Carry from Q 



172 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

If carry indicator ON, then C(Q) - C(Y) -> C(Q) 

IT carry indicator OFF, then C(Q) - C(Y) - 1 -> C(Q) 
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MODIFICATIONS: 



All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Q) = 0, then ON; otherwise OFF 

Negative If C(0J = 1, then ON; otherwise OFF 

Overflow If range of Q is exceeded, then ON 

Carry If a carry out of Q is generated, then ON; otherwise OFF 



NOTES : 



The swcq instruction is identical to the sbq instruction 
with the exception that when the carry indicator is OFF at 
the beginning of the instruction, +1 is subtracted from 
the difference of C(Q) minus C(Y) . The swcq instruction 
treats the carry indicator as the complement of a borrow 
indicator due to the implementation of negative numbers in 
twos complement form. 
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Fixed-Point Multiplication 



mpf 



Multiply Fraction 



FORMAT: 

SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

Zero 

Negative 

Overflow 

NOTES: 



mpy 



401 (0) 



Basic instruction format (see Figure 4-1). 

C(A) Xc(Y) -> C(AQ), left adjusted 

All except ci, sc, scr 

(Indicators not listed are not affected) 

If C(AQ) = 0, then ON; otherwise OFF 
If C(AQ) = 1, then ON; otherwise OFF 
If range of AQ is exceeded, then ON 

Two 36-bit fractional factors ( including sign) are multiplied 
to form a 71-bit fractional product ( including sign) , which 
is stored left-adjusted in the AQ register. AQ ?1 contains 
a zero. Overflow can occur only in the case of A and Y 
containing negative 1 and the result exceeding the range I 
of the AQ register. ■ 







factor 



1 







factor 



Zl 



C(A) 



C(Y) 



yielding 




7 7 

JU 



product 



C(AQ) 



Multiply Integer 



402 (0) 



FORMAT: Basic instruction format (see Figure 4-1). 

SUMMARY: C(Q) X C(Y) -> C(AQ), right adjusted 



2/82 
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MODIFICATIONS: 



All except ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(AQ) = 0, then ON; otherwise OFF 
Negative If C(AQ) = 1, then ON; otherwise OFF 



NOTES: 



Two 36-bit integer factors (including sign) are multiplied 
to form a 71-bit integer product (including sign), which 
is stored right-adjusted in the AQ-register. AQ is 
filled with an "extended sign bit". 




1 



yielding 


1 2 



factor 



C(Q) 




1 



factor 



C(Y) 



product 



C(AQ) 



In the case of (-2**35) X (-2**35) = +2**70, AQ, is used 
to represent the product rather than the sign. No 
overflow can occur. 
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Fixed-Point Division 



div 



Divide Integer 



506 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1) 

C(Q) /(Y) integer quotient -> C(Q) 
integer remainder -> C(A) 



MODIFICATIONS: 
INDICATORS: 



All 



(Indicators not listed are not affected) 



If division takes place: 

Zero If C(Q) = 0, then ON; 
otherwise OFF 

Negative If C(Q) = 1, then ON; 
otherwise OFF 



If no division takes place: 

If divisor = 0, then ON; 
otherwise OFF 

If dividend < 0, then ON; 
otherwise OFF 



NOTES: 



A 36-bit integer dividend (including sign) is divided by a 
36-bit integer divisor (including sign) to form a 36-bit 
integer quotient (including sign) and a 36-bit integer 
remainder (including sign). The remainder sign is equal 
to the dividend sign unless the remainder is zero. 



C(A) 









1 




3 
5 


/ 








1 




3 

«5 


s 


dividend 


s 


divisor 




C(Q) 






C(Y) 




yielding 















1 




3 
5 





1 




3 
5 


s 


remainder. 


s 


quotient 



C(Q) 



If the dividend = -2**35 and the divisor = -1 or if the 
divisor = 0, then division does not take place. Instead, 
a divide check fault occurs, C(Q) contains the dividend 
magnitude, and the negative indicator reflects the 
dividend sign. 
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dvf 



Divide Fraction 



FORMAT: 
SUMMARY: 

MODIFICATIONS: 
INDICATORS: 



507 (0) 



Basic instruction format (see Figure 4-1) 

C(AQ) /(Y) fractional quotient -> C(A) 
fractional remainder -> C(Q) 

All 

(Indicators not listed are not affected) 



If division takes place: 

Zero If C(A) = 0, then ON; 
otherwise OFF 

Negative If C(A) = 1, then ON; 
otherwise OFF 



If no division takes place: 

If divisor = 0, then ON; 
otherwise OFF 

If dividend < 0, then ON; 
otherwise OFF 



NOTES: 



A 71-bit fractional dividend (including sign) is divided 
by a 36-bit fractional divisor yielding a 36-bit 
fractional quotient (including sign) and a 36-bit 



71, 



is 



fractional remainder (including sign). C(AQ) Y , 
ignored; bit position 35 of the remainder corresponds to 
bit position 70 of the dividend. The remainder sign is 
equal to the dividend sign unless the remainder is zero. 
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If jdividendj >= f divisor | or if the divisor = 0, division 

does not take" place. Instead, a divide check fault 
occurs, C(AQ) contains the dividend magnitude in absolute, 
and the negative indicator reflects the dividend sign. 
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Fixed-Point Negate 



neg 



Negate A 



531 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



-C(A) -> C(A) if CCA) t 



MODIFICATIONS: All, but none affect instruction execution, 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 
Negative If C(A) = 1, then ON; otherwise OFF 
Overflow If range of A is exceeded, then ON 



NOTES: 



The neg instruction changes the number in A to its 
negative (if i 0). The operation is performed by forming 
the twos complement of the string of 36 bits. 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



negl 



Negate Long 



533 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



-C(AQ) -> C(AQ) if C(AQ) i 



MODIFICATIONS: All, but none affect instruction execution. 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(AQ) = 0, then ON; otherwise OFF 
Negative If C(AQ) = 1, then ON; otherwise OFF 
Overflow If range of AQ is exceeded, then ON 



NOTES: 



The negl instruction changes the number in AQ to its 
negative (if t 0). The operation is performed by forming 
the twos complement of the string of 72 bits. 
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Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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Fixed-Point Comparison 



cmg 



Compare Magnitude 



FORMAT: Basic instruction format (see Figure 4-1). 

SUMMARY: |c(A)| :: |c(Y)| 

MODIFICATIONS: All 

INDICATORS: (Indicators not listed are not affected) 

Zero If |c(A)| = |c(Y)|, then ON; otherwise OFF 

Negative If |c(A)| < |c(Y)|, then ON; otherwise OFF 



405 (0) 



cmk 



Compare Masked 



FORMAT: 
SUMMARY: 

MODIFICATIONS: 



Basic instruction format (see Figure 4-1) 

For i = 0, 1 , . . . , 35 

C(Z)i = c7bT[ & (c(A) i C(Y)J 

All 



211 (0) 



INDICATORS: 

Zero 
Negative 

NOTES: 



(Indicators not listed are not affected) 

If C(Z) = 0, then ON; otherwise OFF 
If C(Z) = 1, then ON; otherwise OFF 



The cmk instruction compares the contents of bit positions 
of A and Y for identity that are not masked by a 1 in the 
corresponding bit position of Q. 

The zero indicator is set ON if the comparison is 
successful for all bit positions; i.e., if for all 
i = 0, 1,...,35 there is either: C(A)j_ = C(Y) t (the 
identical case) or C(Q)^ = 1 (the masked case); 
otherwise, the zero indicator is set OFF. 

The negative indicator is set ON if the comparison is 
unsuccessful for bit position 0; i.e., if C(A) 9 C(Y) 
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(they are nonidentical) as well as C(Q) Q = (they are 
unmasked); otherwise, the negative indicator is set OFF. 



cmpa 



Compare with A 



115 (0) 



FORMAT: 
SUMMARY: 
MODIFICATIONS: 
INDICATORS: 



Basic instruction format (see Figure 4-1) 



C(A) :: C(Y) 



All 



(Indicators not listed are not affected) 



The zero (Z), negative (N), and carry (C) indicators are 
set as follows: 



Algebraic Comparison (Signed Binary Operands) 



Z N C 



1 

1 1 
1 
1 1 



Relation 
C(A) > C(Y) 
C(A) > C(Y) 
C(A) = C(Y) 
C(A) < C(Y) 
C(A) < C(Y) 



} 



Sign 

C(A) = 0, C(Y) = 1 

C(A) = C(Y) 

C(A) = 1, C(Y) = 



Logical Comparison (Unsigned Positive Binary Operands) 
Z C Relation 

C(A) < C(Y) 

1 1 C(A) = C(Y) 
1 C(A) > C(Y) 



cmpaq 



Compare with AQ 



117 ( 



D 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1). 



C(AQ) :: C(Y-pair) 



MODIFICATIONS: All except du, dl, ci, sc, scr 
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INDICATORS: 



(Indicators not listed are not affected) 



The zero (Z), negative (N), and carry (C) indicators are 
set as follows: 



Algebraic Comparison (Signed Binary Operands) 

Z N C Relation Sign 

C'(AQ) > C(Y-pair) C(AQ) = 0, C(Y-pair) Q = 1 

1 C(AQ) > C(Y-pair) " 

1 1 C(AQ) = C(Y-pair) 
1 C(AQ) < C(Y-pair) _ 
1 1 C(AQ) < C(Y-pair) C(AQ) = 1, C(Y-pair) = 



► C(AQ) = C(Y-pair) 



Logical Comparison (Unsigned Positive Binary Operands) 
Z C Relation 

C(AQ) < C(Y-pair) 

1 1 C(AQ) = C(Y-pair) 
1 C(AQ) > C(Y-pair) 



cmpq 



Compare with Q 



116 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(Q) :: C(Y) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



The zero (Z), negative (N), and carry (C) indicators are 
set as follows: 
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Algebraic Comparison (Signed Binary Operands) 
Z N C Relation Sign 



C(Q) > C(T) 



1 

1 1 
1 
1 1 



C(Q) > C(Y) 
C(Q) = C(Y) 
C(Q) < C(Y) 
C(Q) < C(Y) 



I 



C(Q) = 0, C(Y) = 1 

C(Q) = C(Y) 

C(Q) = 1, C(Y) = 



Logical Comparison (Unsigned Positive Binary Operands) 
Z C Relation 

C(Q) < C(Y) 

1 1 C(Q) = C(Y) 
1 C(Q) > C(Y) 



cmpxn 



Compare with Index Register n 



lOn (0) 



FORMAT: 
SUMMARY: 

MODIFICATIONS: 
INDICATORS: 



Basic instruction format (see Figure 1-1). 

For n s 0, 1, ..., or 7 as determined by operation code 
C(Xn) :: C(Y) 0fl7 

All except ci, sc, scr 

(Indicators not listed are not affected) 



The zero (Z), negative (N), and carry (C) indicators are 
set as follows: 



Algebraic Comparison (Signed Binary Operands) 
Z N C Relation Sign 





1 

1 1 
1 
-1 1 



C(Xn) > C(Y) 0tl7 C(Xn) s 0, C(Y) 

C(Xn) > C(Y) 0>17 " 

C(Xn) s C(Y) 0j17 ► C(Xn) = C(Y) 

C(Xn) < C(Y) 0>17 „ 

C(Xn) < C(Y) 0>17 C(Xn) = 1, C(Y) 



3 



4-67 



AL39 



FIXED-POINT COMPARISON 



Logical Comparison (Unsigned Positive Binary Operands) 
Z C Relation 




C(Xn) < C(Y) 0>17 

0,17 
C(Xn) > C(Y) 17 



1 1 C(Xn) = C(Y) 



cwl 



Compare with Limits 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: 



C(Y) :: closed interval [c(A);C(Q)l 
C(Y) :: C(Q) 



MODIFICATIONS: All 

INDICATORS: (Indicators not listed are not[ affected) 



111 (0) 



Zero 



NOTES: 



If C(A) <= C(Y) <= C(Q) or C(A) >= C(Y) >= C(Q), then ON; 
otherwise OFF. 

The negative (N) and carry (C) indicators are set as 
follows: 



N C 



Relation 



Sign 



C(Q) > C(Y) C(Q) = 0, C(Y) = 1 

1 C(Q) 

1 C(Q) 



>= C(Y) "1 
< C(Y) J 



C(Q) n = C(Y), 



1 1 



C(Q) < C(Y) C(Q) = 1, C(Y), 



The cwl instruction tests the value of C(Y) to determine 
if it is within the range of values set by C(A) and C(Q) . 
The comparison of C(Y) with C(Q) locates C(Y) with respect 
to the interval if C(Y) is not contained within the 
interval. 



4-68 



AL39 



FIXED-POINT MISCELLANEOUS 



Fixed-Point Miscellaneous 



szn 



Set Zero and Negative Indicators 



FORMAT: Basic instruction format (see Figure 4-1) 
SUMMARY: Set indicators according to C(Y) 
MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y) = 0, then ON; otherwise OFF 
Negative If C(Y) = 1, then ON; otherwise OFF 



sznc 



Set Zero and Negative Indicators and Clear 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: Set indicators according to C(Y) 
00*. .0 => C(Y) 

MODIFICATIONS: All except du, dl, ci, sc, ser 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y) = 0, then ON, otherwise OFF 
Negative If C(Y) = 1, then ON; otherwise OFF 



234 (0) 



214 (0) 



4-69 



AL39 



BOOLEAN AND 



BOOLEAN OPERATION INSTRUCTIONS 



Boolean AND 



ana 



AND to A 



375 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



C(k) 1 & C(Y) t -> C(A) t for i = (0, 1, .... 35) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 
Negative If C(A) = 1, then ON; otherwise OFF 



anaq 



AND to AQ 



377 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



CUQJi 4 C(Y-pair) i -> C(AQ) i for i = (0, 1, ..., 71) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(AQ) = 0, then ON; otherwise OFF 
Negative If C(AQ) =.1, then ON; otherwise OFF 



4-70 



AL39 



BOOLEAN AND 



anq 



AND to Q 



376 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: C^Q^ & CCY^ -> C(Q) i for i = (0, 1, ..., 35) 
MODIFICATIONS: All 



INDICATORS: 

Zero 
Negative 



(Indicators not listed are not affected) 

If C(Q) = 0, then ON; otherwise OFF 
If C(Q) = 1, then ON; otherwise OFF 



ansa 



AND to Storage A 



FORMAT: 



Basic instruction format (see Figure 4-1). 



355 (0) 



SUMMARY: CU) t & C(Y) i -> C(Y)i for i i (0, 1 35) 

MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 

Zero 
Negative 

NOTES: 



(Indicators not listed are not affected) 

If C(Y) = 0, then ON; otherwise OFF 
If C(Y) = 1, then ON; otherwise OFF 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



4-71 



AL39 



BOOLEAN AND 



ansq 



AND to Storage Q 



356 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: C(Q) i & CCY^ -> C(Y) i for i = (0, 1, ,.., 35) 

MODIFICATIONS: All except du, dl, ci, so, scr 



INDICATORS: 

Zero 
Negative 

NOTES : 



(Indicators not listed are not affected) 

If C(Y) = 0, then ON; otherwise OFF 
If C(Y) = 1, then ON; otherwise OFF 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



ansxn 



AND to Storage Index Register n 



FORMAT: 



SUMMARY: 



INDICATORS: 

Zero 
Negative 

NOTES: 



34n (0) 



] 



Basic instruction format (see Figure 1-1). 

For n =-0, 1, ..., or 7 as determined by operation code 
C(Xn) i & C(Y) t -> C(Y) i for i = (0, 1, ..., 17) 



MODIFICATIONS: All except du f dl, ci, sc, scr 



(Indicators not listed are not affected) 

If C(Y) 17 = 0, "then ON; otherwise OFF 
If C(Y) = 1, then ON; otherwise OFF 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



4-72 



AL39 



BOOLEAN AND 



anxn 



AND to Index Register n 



36n (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, ..., or 7 as determined by operation code 
CCXnJj & C(Y) i -> C.(Xn) i for J = (0, 1, ... , 17) 



MODIFICATIONS: All except ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Xn) = 0, then ON; otherwise OFF 
Negative If C(Xn) = 1, then ON; otherwise OFF 



4-73 



AL39 



BOOLEAN OR 



Boolean Or 



ora 



OR to A 



FORMAT: 



SUMMARY: 



275 (0) 



Basic instruction format (see Figure 4-1). 



C(A) i | C(Y)i -> C(A) 1 for i = (0, 1 35) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 
Negative If C(A) = 1, then ON; otherwise OFF 



oraq 



OR to AQ 



277 (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1). 



C(AQ) i | C(Y-pair) i -> C(AQ) i for i = (0, 1, ..., 71) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(AQ) = 0, then ON; otherwise OFF 
Negative If C(AQ) = 1, then ON; otherwise OFF 



4-74 



AL39 



BOOLEAN OR 



orq 



OR to Q 



276 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



0(0^ ! C(Y)i -> C(Q) i for i s (0, 1, .... 35) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Q) s 0, then ON; otherwise OFF 
Negative If C(Q) = 1, then ON; otherwise OFF 



orsa 



OR to Storage A 



255 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



C(A) t | C(Y) i -> C(Y)i for i * (0, 1, ..., 35) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y) = 0, then ON; otherwise OFF 
Negative If C(Y) = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



4-75 



AL39 



BOOLEAN OR 



orsq 



OR to Storage Q 



256 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C<Q) i | C(Y) i ->' C(Y) i for 1 x (0, 1, ..., 35) 



MODIFICATIONS: All except du, dl, el, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y) = 0, then ON; otherwise OFF 
Negative If C(Y) = 1, then ON; otherwise OFF 

NOTES: Attempted repetition with the rpl instruction causes an 

illegal procedure fault. 



orsxn 



OR to Storage Index Register n 



24n (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



For n = 0, 1, . . . , or 7 as determined by operation code 
C(Xn) 1 { C(Y) i -> C(Y)i for i = (0,1, ..., 17) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 
Negative 



If C(Y) 17 = 0, then ON; otherwise OFF 
If C(Y) = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



4-76 



AL39 



BOOLEAN OR 



orxn 



OR to Index Register n 



26n (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) . 



SUMMARY: 



For n = 0, 1, . . . , . or 7 as determined by operation code 
C(Xn) i i cm L -> CUn^ for i = (0, 1, .... 17) 



MODIFICATIONS: All except ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Xn) = 0, then ON; otherwise OFF 
Negative If C(Xn) = 1, then ON; otherwise OFF 



H-77 



AL39 



BOOLEAN EXCLUSIVE OR 



Boolean Exclusive Or 



era 



EXCLUSIVE OR to A 



675 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: C(A) t CCY^ -> C(A) t for i = (0, 1 35) 

MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 
Negative If C(A) = 1, then ON; otherwise OFF 



eraq 



EXCLUSIVE OR to AQ 



FORMAT: 



Basic instruction format (see Figure 4-1) 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(AQ) = 0, then ON; otherwise OFF 
Negative If C(AQ) = 1, then ON; otherwise OFF 



677 CO) 



SUMMARY: CUQ) ± C(Y-pair) i -> C(AQ) i for i = (0, 1, ..., 71) 
MODIFICATIONS: All except du, dl, ci, sc, scr 



4-78 



AL39 



BOOLEAN EXCLUSIVE OR 



erq 



EXCLUSIVE OH to Q 



676 (0) 



FORMAT: 



Basic instruction- format (see Figure 4-1). 



SUMMARY: 



C(Q)i cmj -> C(Q) i for i = (0, 1, .... 35) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Q) = 0, then ON; otherwise. OFF 
Negative If C(Q) = 1, then ON; otherwise OFF 



ersa 



EXCLUSIVE OR to Storage A 



655 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



C(A)i C(Y)i -> C(Y)i for i = (0, 1, ... , 35) 



MODIFICATIONS: All except du-, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y) = 0, then ON; otherwise OFF 
Negative If C(Y) = 1, then ON; otherwise OFF 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



4-79 



AL39 



BOOLEAN EXCLUSIVE OR 



ersq 



EXCLUSIVE OR to Storage Q 



656 (0) 



FORMAT: Basic instruction format (see Figure 4-1). 

SUMMARY: CiQ) i CCY^ -> CCY^ for i = (0, 1, ..., 35) 
MODIFICATIONS: All except du, dl, ci, so, scr 



INDICATORS: 

Zero 
Negative 

NOTES: 



(Indicators not listed are not affected) 

If C(Y) = 0, then ON; otherwise OFF 
If C(Y) = 1, then ON; otherwise OFF 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



ersxn 



EXCLUSIVE OR to Storage Index Register n 



FORMAT: 



SUMMARY: 



MODIFICATIONS: 



INDICATORS: 



Zero 
Negative 



NOTES: 



64n (0) I 



Basic instruction format (see Figure 4-1). 

For n = 0, 1 , . .., or 7 as determined by operation code 
C(Xn) i C(Y)i -> C(Y)i for i = (0, 1, ..., 17) 

All except du, dl, ci, se, scr 

(Indicators not listed are not affected) 

If C(Y) 0j17 = 0, then 0M; otherwise OFF 
If C(Y) = 0, then ON; otherwise OFF 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



4-80 



AL39 



BOOLEAN EXCLUSIVE OR 



erxn 



EXCLUSIVE OR to Index Register n 



66n (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, ..., or 7 as determined by operation code 
C(Xn) i C(Y) i -> CUn^ for i = (0, 1, .... 17) 



MODIFICATIONS: All except ci, se, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Xn) = 0, then ON; otherwise OFF 
Negative If C(Xn) = 1, then ON; otherwise OFF 



4-81 



AL39 



BOOLEAN COMPARATIVE AND 



Boolean Comparative And 



can a 



Comparative AND with A 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: CU^ = C(A> i & C(Y) t for i = (0, 1, ...,35) 
MODIFICATIONS: All 



INDICATORS: 

ZERO 
Negative 



(Indicators not listed are not affected) 

If C(Z) = 0, then ON; otherwise OFF 
If C(Z) = 1, then ON; otherwise OFF 



canaq 



Comparative AND with AQ 



FORMAT: 



INDICATORS: 



Basic instruction format (see Figure 4-1) 



(Indicators not listed are not affected) 



Zero If C(Z) = 0, then ON; otherwise OFF 
Negative If C(Z) S = 1, then ON; otherwise OFF 



315 (0) 



317 (0) 



SUMMARY: C(Z) t = C(AQ) i 4 C(Y-pair) i for i = (0, 1 , . . . , 71 ) 
MODIFICATIONS: All except du, dl, ci, sc, scr 



4-82 



AL39 



BOOLEAN COMPARATIVE AND 



canq 



Comparative AND with Q 



316 (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4—1) 



C(Z) i = C(Q) ± & C(Y)i for i = (0, 1 , . . . , 35) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



ZERO If C(Z) = 0, then ON; otherwise OFF 
Negative If C(Z) = 1, then ON; otherwise OFF 



canxn 



Comparative AND with Index Register n 



30n (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1). 

For n = 0,1, . .., or 7 as determined by operation code 
C(Z)i = CCXn)^ & C(Y) t for i = (0, 1, ..., 17) 



MODIFICATIONS: All except ei, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Z) = 0, then ON; otherwise OFF 
Negative If C(Z) = 1, then ON; otherwise OFF 



4-83 



AL39 



BOOLEAN. COMPARATIVE NOT 



Boolean Comparative Not 



cnaa 



Comparative NOT' with A 



215 (0) 



FORMAT: Basic instruction format (see Figure 4-1). 

SUMMARY: C(Z)i = CU^ & cTT) t for i = (0, 1 35) 

MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Z) = 0, then ON; otherwise OFF 
Negative If C(Z) = 1, then ON; otherwise OFF 



cnaaq 



Comparative NOT with AQ 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: CU^ = C(AQ) i & C(Y-pair) i for i = (0, 1, 
MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Z) = 0, then ON; otherwise OFF 
Negative If C(Z) Q = 1, then ON; otherwise OFF 



217 (0) 



.., 71) 



cnaq 



Comparative NOT with Q 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(Z)i = C(Q) i & cTD i for i = (0, 1, ..., 35) 



MODIFICATIONS: All 



INDICATORS: 



(Indicators not listed are not affected) 



216 (0) 



4-84 



AL39 



BOOLEAN COMPARATIVE HOT 



Zero If C(Z) = 0, then ON; otherwise OFF 
Negative If C(Z) = 1, then ON; otherwise OFF 



cnaxn 



Comparative NOT with Index Register n 



FORMAT: 



SUMMARY: 



INDICATORS: 



20n ( 



q 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, ..., or 7 as determined by operation code 
C(Z) i = C(Xn) i & cTYli for i = (0, 1, ..., 17) 



MODIFICATIONS: All except ci, sc, scr 



(Indicators not listed are not affected) 



Zero If C(Z) = 0, then ON; otherwise OFF 
Negative If C(Z) = 1, then ON; otherwise OFF 



4-85 



AL39 



FLOATING-POINT. DATA MOVEMENT LOAD 



FLOATING-POINT ARITHMETIC INSTRUCTIONS 



Floating-Point Data Movement Load 



dfld 



Double-Precision Floating Load 



433 (0) 



FORMAT: 



SUMMARY: 



MODIFICATIONS: 



INDICATORS: 



Basic instruction format (see Figure 4-1), 

C(Y-pair) 7 -> C(E) 
C(Y-pair) 8>?1 -> C(AQ) 0>63 
00. ..0 -> C(AQ) 6i| ?1 

All except du, dl, ci, sc, scr 

(Indicators not listed are not affected) 



Zero If C(AQ) = 0, then ON; otherwise OFF 
Negative If C(AQ) Q = 1, then ON; otherwise OFF 



fid 



Floating Load 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1). 

C(Y) Q j -> C(E) 
C(Y) 8>35 -> C(AQ) 0f27 
00. ..0 -> C(AQ) 30 ?1 



MODIFICATIONS: All except ci, sc, scr 



431 (0) 



INDICATORS: 

Zero 
Negative 



(Indicators not listed are not affected) 

If C(AQ) s 0, then ON; otherwise OFF 
IF C(AQ) = 1, then ON; otherwise OFF 



2/82 



4-86 



AL39B 



FLOATING-POINT DATA MOVEMENT STORE 



Floating-Point Data Movement Store 



dfst 



Double-Precision Floating Store 



457 (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 

C(E) -> C(Y-pair) 07 
C(AQ) 0,63 -> C(Y-pair) 871 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



dfstr 



Double-Precision Floating Store Rounded 



472 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



C(EAQ) rounded -> C(Y-pair) (as in dfst) 



MODIFICATIONS: All except du, dl, ei, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 



If C(Y-pair) = floating point 0, then ON; otherwise OFF 
If C(Y-pair)g = 1, then ON; otherwise OFF 
If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 



NOTES: 



The dfstr instruction performs a double-precision true 
round and normalization on C(EAQ) as it is stored. 

The definition of true round is located under the 
description of the frd instruction. 

The definition of normalization is located under the 
description of the fno instruction. 



4-87 



AL39 



FLOATING-POINT DATA MOVEMENT STORE 



Except for the precision of the stored result, the dfstr 
instruction is identical to the fstr instruction. 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



fst 



Floating Store 



455 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(E) -> C(Y) 0f7 
C(A) 0>27 -> C(Y) 8)35 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



fstr 



Floating Store Rounded 



470 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(EAQ) rounded -> C(Y) (as in fst) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 



If C(Y) = floating point 0, then ON; otherwise OFF 

If C(Y)g = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 



NOTES: 



The fstr instruction performs a true round and 
normalization on C(EAQ) as it is stored. 

The definition of true round is located under the 
description of the frd instruction. 



4-88 



AL39 



FLOATING-POINT DATA MOVEMENT STORE 



The definition of normalization is located under the 
description of the fno instruction. 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



4-89 AL39 



FLOATING-POINT ADDITION 



Floating-Point Addition 



dfad 



Double-Precision Floating Add 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: (c(EAQ) + C(Y-pair)) normalized -> C(EAQ) 
MODIFICATIONS: All except du, dl , ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



477 (0) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 



Carry 



NOTES: 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 

If a carry out of AQ is generated, then ON; otherwise OFF 

The dfad instruction may be thought of as a dufa 
instruction followed by a fno instruction. 

The definition of normalization is located under the 
description of the fno instruction. 



dufa 



Double-Precision Unnormalized Floating Add 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(EAQ) + C(Y-pair) -> C(EAQ) 



437 (0) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 



4-90 



AL39 



FLOATING-POINT ADDITION 



Exponent If exponent is less than -128, then ON 
Underflow 



Carry 



NOTES: 



If a carry out of AQ is generated , then ON; otherwise OFF 

Except for the precision of the mantissa of the operand 
from main memory, the dufa instruction is identical to the 
ufa instruction. 



fad 



Floating Add 



475 (0) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: (c(EAQ) + C(Y)) normalized -> C(EAQ) 
MODIFICATIONS: All except ci , sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 

Carry 



NOTES: 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 

If a carry out of AQq is generated, then ON; otherwise OFF 

The fad instruction may be thought of a an ufa instruction 
followed by a fno instruction. 

The definition of normalization is located under the 
description of the fno instruction. 



ufa 



Unnormalized Floating Add 



435 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(EAQ) + C(Y) -> C(EAQ) 



MODIFICATIONS: All except ci, sc, scr 
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INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 

Carry 



NOTES: 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 

If a carry out of AQ is generated, then ON; otherwise OFF 

The ufa instruction is executed as follows: 

The mantissas are aligned by shifting the mantissa of 
the operand having the algebraically smaller exponent 
to the right the number of places equal to the 
absolute value of the difference in the two 
exponents. Bits shifted beyond the bit position 
equivalent to AQ^ 1 are lost. 

The algebraically larger exponent replaces C(E). 

The sum of the mantissas replaces C(AQ). 

If an overflow occurs during addition, then; 

C(AQ) are shifted one place to the right. 

C(AQ) is inverted to restore the sign. 

C(E) is increased by one. 
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Floating-Point Subtraction 



dfsb 



Double-Precision Floating Subtract 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: (c(EAQ) - C(Y-pair)) normalized -> C(EAQ) 
MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



577 (0) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 

Carry 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 

If a carry out of AQ is generated, then ON; otherwise OFF 



NOTES: 



The dfsb instruction is identical to the dfad instruction 
with the exception that the twos complement of the 
mantissa of the operand from main memory is used. 



dufs 



Double-Precision Unformalized Floating Subtract 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(EAQ) - C(Y-pair) -> C(EAQ) 



537 (0) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 
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Exponent 
Underflow 



If exponent is less than -128, then ON 



Carry If a carry out of AQ is generated, then ON; otherwise OFF 



NOTES: 



Except for the precision of the mantissa of the operand 
from main memory, the dufs instruction is identical with 
the ufs instruction. 



fsb 



Floating Subtract 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: (c(EAQ) - C(Y)] normalized -> C(EAQ) 
MODIFICATIONS: All except ci, sc , scr 



INDICATORS: 

Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 

Carry 



575 (0) 



NOTES: 



(Indicators not listed are not affected) 

If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 

If a carry out of AQ is generated, then ON; otherwise OFF 

The fsb instruction may be thought of as an ufs 
instruction followed by a fno instruction. 

The definition of normalization is located under the 
description of the fno instruction. 
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ufs 



Unnormalized Floating Subtract 



535 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(EAQ) - C(Y) -> C(EAQ) 



MODIFICATIONS: All except ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 

Carry 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127 , then ON 

If exponent is less than -128, then ON 

If a carry out of AQq is generated, then ON; otherwise OFF 



NOTES: 



The ufs instruction is identical to the ufa instruction 
with the exception that the twos complement of the 
mantissa of the operand from main memory is used. 
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Floating-Point Multiplicatio n 



dfmp 



Double-Precision Floating Multiply 



INDICATORS: 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: (c(EAQ) X C(Y-pair)] normalized -> C(EAQ) 
MODIFICATIONS: All except du, dl, ci, sc, scr 



(Indicators not listed are not affected) 



463 (0) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 



NOTES: 



The dfmp instruction may be thought of as a dufm 
instruction followed by a fno instruction. 

The definition of normalization is located under the 
description of the fno instruction. 



dufm 



Double-Precision Unnormalized Floating Multiply 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(EAQ) Xc(Y-pair) -> C(EAQ) 



423 (0) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 
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Exponent 
Underflow 



If exponent is less than -128, then ON 



NOTES: 



Except for . the precision of the mantissa of the operand 
from main memory, the dufm instruction is identical to the 
ufm instruction. 



fmp 



Floating Multiply 



461 (0) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: (c(EAQ) X C(Y)] normalized -> C(EAQ) 
MODIFICATIONS: All except ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 



NOTES : 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 



The fmp instruction may be thought of as a ufm instruction 
followed by a fno instruction. 

The definition of normalization is located under the 
description of the fno instruction. 
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ufm 



Unnormalized Floating Multiply 



421 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(EAQ) XC(Y) -> C(EAQ) 



MODIFICATIONS: All except ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 



NOTES: 



The ufm instruction is executed as follows: 

C(E) + C(Y) 0)7 -> C(E) 

(C(AQ) Xc(Y) 8f35 ) 0)71 -> C(AQ) 

A normalization is performed only in the case of both 
factor mantissas being 100... which is the twos 
complement approximation to the decimal value -1.0. 

The definition of normalization is located under the 
description of the fno instruction. 
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Floating-Point Division 



dfdi 



Double-Precision Floating Divide Inverted 



527 (0) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: C(Y-pair) /c(EAQ) -> C(EAQ) 
MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 
Negative 



Exponent 
Overflow 

Exponent 
Underflow 



If division takes place: If no division takes place: 



If C(AQ) = 0, then ON; 
otherwise OFF 

If C(AQ) = 1, then ON; 
otherwise OFF 



If divisor mantissa = 0, 
then ON; otherwise OFF 

If dividend < 0, then ON; 
otherwise OFF 



If exponent is greater than +127, then ON 



If exponent is less than -128, then ON 



NOTES: 



Except for the interchange of the roles of the operands, 
the execution of the dfdi instruction is identical to the 
execution of the dfdv instruction. 

If the divisor mantissa C(AQ) is zero, the division does 
not take place. Instead, a divide check fault occurs and 
all registers remain unchanged. 



dfdv 



Double-Precision Floating Divide 



567 (0) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: C(EAQ) /c(Y-pair) -> C(EAQ) 
MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 
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If division takes place: If no division takes place: 



Zero 



Negative 



Exponent 
Overflow 

Exponent 
Underflow 



If CCAQ) = 0, then ON; 
otherwise OFF 

If C(AQ) = 1, then ON; 
otherwise OFF 



If divisor mantissa =0, 
then ON; otherwise OFF 

If dividend < 0, then ON; 
otherwise OFF 



If exponent is greater than +127, then ON 



If exponent is less than -128, then ON 



NOTES: 



The dfdv instruction is executed as follows: 

The dividend mantissa C(AQ) is shifted right and the 
dividend exponent C(E) increased accordingly until 

l c(AQ) 0,63l < | C(Y -P air >8,7l| 
C(E) - C(Y-pair) 0j7 -> C(E) 

C(AQ) /c(Y-pair) 8>71 -> C(AQ) 0|63 

00. ..0 -> C(Q) 64>71 

If the divisor mantissa C(Y-pair)o 71 is zero after 
alignment, the division does not take place. Instead, a 
divide check fault occurs, C(AQ) contains the dividend 
magnitude, and the negative indicator reflects the 
dividend sign. 



fdi 



Floating Divide Inverted 



525 (0) 



FORMAT: Basic instruction format (see Figure 4-1). 

SUMMARY: C(Y) /c(EAQ) -> C(EA) 

00. ..0 -> C(Q) 

MODIFICATIONS: All except ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



If division takes place: If no division takes place: 



Zero If C(A) = 0, then ON; 
otherwise OFF 

Negative If C(A) = 1, then ON; 
otherwise OFF 



If divisor mantissa = 0, then 
ON; otherwise OFF 

If dividend < 0, then ON; 
otherwise OFF 
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Exponent 
Overflow 

Exponent 
Underflow 



If exponent is greater than +127, then ON 



If exponent is less than -128, then ON 



NOTES: 



Except for the interchange of roles of the operands, the 
execution of the fdi instruction is identical to the 
execution of the fdv instruction. 

If the divisor mantissa C(AQ) is zero, the division does 
not take place. Instead, a divide check fault occurs and 
all the registers remain unchanged. 



fdv 



Floating Divide 



565 (0) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY C(EAQ) /c(Y) -> C(EA) 

00.. .0 -> C(Q) 

MODIFICATIONS: All except ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



If division takes place: 



If no division takes place; 



Zero 



Negative 



Exponent 
Overflow 

Exponent 
Underflow 



If C(A) = 0, then ON; 
otherwise OFF 

If C(A) = 1, then ON; 
otherwise OFF 



If divisor mantissa = 0, then 
ON; otherwise OFF 

If dividend < 0, then ON; 
otherwise OFF 



If exponent is greater than +127, then ON 



If exponent is less than -128, then ON 



NOTES: 



The fdv instruction is executed as follows: 

The dividend mantissa C(AQ) is shifted right and the 
dividend exponent C(E) increased accordingly until 

|c(AQ) 0f27 | < |c(Y) 8f35 | 

C(E) - C(Y) 0>7 -> C(E) 
C(AQ) /c(Y) 8>35 -> C(A) 
00.. .0 -> C(Q) 
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If the divisor mantissa C(Y) 8 35 is zero after alignment, 
the division does not take place. Instead, a divide check 
fault occurs, C(AQ) contains the dividend magnitude, and 
the negative indicator reflects the dividend sign. 
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Floating-Point Negate 



fneg 



Floating Negate 



513 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



-C(EAQ) normalized -> C(EAQ) 



MODIFICATIONS: All, but none affect instruction execution. 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 



If C(AQ) = 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 



NOTES: 



This instruction changes the number in C(EAQ) to its 

normalized negative (if C(AQ) t 0). The operation is 

executed by first forming the twos complement of C(AQ), 
and then normalizing C(EAQ). 

Even if originally C(EAQ) were normalized, an exponent 
overflow can still occur, namely when C(E) = +127 and 
C(AQ) = 100. ..0 which is the twos complement approximation 
for the decimal value -1.0. 

The definition of normalization may be found under the 
description of the fno instruction. 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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Floating-Point Normalize 



fno 



Floating Normalize 



573 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(EAQ) normalized -> C(EAQ) 



MODIFICATIONS: All, but none affect instruction execution. 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 

Overflow 



If C(EAQ) = floating point 0, then ON; otherwise OFF 

If C(AQ) Q = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then ON otherwise OFF 

Set OFF 



NOTES: 



The fno instruction normalizes the number in C(EAQ) if 
C(AQ) H and the overflow indicator is OFF. 

A normalized floating number is defined as one whose 
mantissa lies in the interval [0.5,1.0] such that 



0.5 < = 



:(AQ)| 



< 1.0 



which, in turn, requires that C(AQ) n £ C(AQ) 



If the overflow indicator is ON, then C(AQ) is shifted one 
place to the right, C(AQ) Q is inverted to reconstitute the 
actual sign, and the overflow indicator is set OFF. This 
action makes the fno instruction useful in correcting 
overflows that occur with fixed point numbers. 

Normalization is performed by shifting C(AQ)-, 71 one place 
to the left and reducing C(E) by 1, repeatedly, until the 



conditions for C(AQ) Q and C(AQ) 1 are met. 
out of AQ-| are lost. 



Bits shifted 



If C(AQ) = 0, then C(E) 
indicator is set ON. 



is set to -128 and the zero 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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Floating-Point Round 



dfrd 



Double-Precision Floating Round 



FORMAT: Basic instruction format (see Figure 4-1). 

SUMMARY: . C(EAQ) rounded to 64 bits -> C(EAQ) 
-> CCAQ) 65f71 

MODIFICATIONS: All, but none affect instruction execution 



473 (0) 



INDICATORS: 

Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 



(Indicators not listed are not affected) 

If C(EAQ) = floating point 0, then ON; otherwise OFF 

If C(AQ) = 1, then ON; otherwise OFF 

If exponent is greater than +127, then ON 

If exponent is less than -128, then OH 



NOTES : 



The dfrd instruction is identical to the frd instruction 
except that the rounding constant used is (11...1) fi e 71 
instead of (11...1) 2g 71 . "'" 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



frd 



Floating Round 



471 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: C(EAQ) rounded to 28 bits -> C(EAQ) 
-> C(AQ) 29t71 

MODIFICATIONS: All, but none affect instruction execution, 



INDICATORS: 

Zero 
Negative 



(Indicators not listed are not affected) 

If C(EAQ) = floating point 0,.then ON; otherwise OFF 
If C(AQ) = 1 then ON; otherwise OFF 



4-105 



AL39 



FLOATING-POINT ROUND 



Exponent If exponent is greater than +127, then ON 
Overflow 

Exponent If exponent is less than -128, then ON 
Underflow 



NOTES: 



If C(AQ) i 0, the frd instruction performs a true round to 
a precision of 28 bits and a normalization on C(EAQ). 

A true round is a rounding operation such that the sum of 
the result of applying the operation to two numbers of 
equal magnitude but opposite sign is exactly zero. 

The frd instruction is executed as follows: 

C(AQ)*+ (11...1) 29>71 -> C(AQ) 

If C(AQ) = 0, then a carry is added at AQ 71 

If overflow occurs, C(AQ) is shifted one place to the 
right and C(E) is increased by 1. 

If overflow does not occur, C(EAQ) is normalized. 

If C(AQ) = 0, C(E) is set to -128 and the zero indicator 
is set ON. 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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Floating-Point Compare 



dfcmg 



Double-Precision Floating Compare Magnitude 



427 (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 

C(E) :: C(Y-pair) 07 
|cCAQ) 0j63 | :: |c(Y-palr) 8f71 | 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 

Zero 
Negative 

NOTES: 



(Indicators not listed are not affected) 



If 
If 



C(EAQ) 
C(EAQ) 



= Jc(Y-pair)J, then ON; otherwise OFF 
< Jc(Y-pair)J, then ON; otherwise OFF 



The dfcmg instruction is identical to the dfcmp 
instruction except that the magnitudes of the mantissas 
are compared instead of the algebraic values. 



dfcmp 



Double-Precision Floating Compare 



517 (0) 



FORMAT: 



Basic instruction format (see Figure 1-1) 



SUMMARY: 



C(E) :: C(Y-pair) 7 
C(AQ) 0,63 :: C(Y-pair) 8)71 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(EAQ) = C(Y-pair), then ON; otherwise OFF 
Negative If C(EAQ) < C(Y-pair), then ON; otherwise OFF 



NOTES: 



The dfcmp instruction is identical to the fcmp instruction 
except for the precision of the mantissas - actually 
compared. 
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fcmg 



Floating Compare Magnitude 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1) 

C(E) :: C(Y) 0f? 
|c(AQ) 0f27 | :: |c(I) 8 35 | 



MODIFICATIONS: All except ci, sc, scr 

INDICATORS: (Indicators not listed are not affected) 



Zero 
Negative 



If JC(EAQ)[ = |c(Y) 
If |c(EAQ)| < |c(Y) 



, then ON; otherwise OFF 
, then ON; otherwise OFF 



425 (0) 



NOTES: 



The fcmg instruction is identical to the fcmp instruction 
except that the magnitudes of the mantissas are compared 
instead of the algebraic values. 



fcmp 



Floating Compare 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(E) :: C(Y), 



'0,7 
C(AQ) 0f27 :: C(Y) 8?35 



MODIFICATIONS: All except ci, sc, scr 



INDICATORS: 

Zero 
Negative 

NOTES: 



515 (0) 



(Indicators not listed are not affected) 

If C(EAQ) = C(Y), then ON; otherwise OFF 
If C(EAQ) < C(Y), then ON; otherwise OFF 

The fcmp instruction is executed as follows: 

The mantissas are aligned by shifting the mantissa of 
the operand with the algebraically smaller exponent 
to the right the number of places equal to the 
difference in the two exponents. 

The aligned mantissas are compared and the indicators 
set accordingly. 
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Floating-Point Miscellaneous 



ade 



Add to Exponent 



FORMAT: 



INDICATORS: 

Zero 

Negative 

Exponent 
Overflow 

Exponent 
Underflow 



Basic instruction format (see Figure 4-1). 



SUMMARY: C(E) + C(Y) 0>7 -> C(E) 
MODIFICATIONS: All except ci, sc, scr 



(Indicators not listed are not affected) 

Set OFF 
Set OFF 
If exponent is greater than +127, then ON 

If exponent is less than -128, then ON 



415 (0) 



fszn 



Floating Set Zero and Negative Indicators 



FORMAT: 



SUMMARY: 



INDICATORS: 



Basic instruction format (see Figure 4-1) 



Set indicators according to C(Y) 



MODIFICATIONS: All except ci, sc, scr 



(Indicators riot listed are not affected) 



Zero If C(Y) 8f35 = 0, then ON; otherwise OFF 
Negative If 0(Y) 8 = 1, then ON; otherwise OFF 



430 (0) 



lde 



Load Exponent 



411 (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(Y) 0f7 -> C(E) 
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MODIFICATIONS: All except ci, sc , scr 

INDICATORS: (Indicators not listed are not affected) 

Zero Set OFF 

Negative Set OFF 



ste 



Store Exponent 



456 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(E) -> C(Y) 7 
00. ..0 -> C(Y)g 17 



MODIFICATIONS: All except du, dl, ci, sc, sor 



INDICATORS: 



None affected 
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TRANSFER INSTRUCTIONS 



ca!16 



Call (Using PR6 and PR7) 



713 (0) 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



Basic instruction format (see Figure 4-1). 

If C(TPR.TRR) < C(PPR.PRR) then 

C(DSBR. STACK) | i C(TPR.TRR) -> C(PR7.SNR) 

If C(TPR.TRR) = C(PPR.PRR) then C(PR6.SNR) -> C(PR7-SNR) 

C(TPR.TRR) -> C(PR7.RNR) 

If C(TPR.TRR) = then C(SDW.P) -> C(PPR.P); 
otherwise -> C(PPR.P) 

00... -> C(PR7.WORDNO) 

00... -> C(PR7.BITNO) 

C(TPR.TRR) -> C(PPR.PRR) 

C(TPR.TSR) -> C(PPR.PSR) 

C(TPR.CA) -> C(PPR.IC) 

All except du, dl, ci, sc, scr 

None affected 



See Section 3 for descriptions of the various registers 
and Section 8 for a flowchart of their role in address 
preparation. 

If C(TPR.TRR) > C(PPR.PRR), an access violation fault 
(outward call) occurs and the call6 instruction is not 
executed. 

If the call6 instruction is executed with the processor in 
absolute mode with bit 29 of the instruction word set OFF 
and without indirection through an itp or its pair, then: 

the appending mode is entered for the address 
preparation of the call6 operand address and is 
retained if the instruction executes successfully, 

and the effective segment number generated for the 
SDW fetch and subsequent loading into C(TPR.TSR) is 
equal to C(PPR.PSR) and may be undefined in absolute 
mode , 

and the effective ring number loaded into C(TPR.TRR) 
prior to the SDW fetch is equal to C(PPR.PRR) (which 
is in absolute mode) implying that the access 
violation checks for outward call and bad outward 
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call are ineffective and that an access violation 
(out of call brackets) will occur if C(SDW.Rl) i 0. 

Attempted repetition with the rpt, rpd , or rpl 
instructions causes an illegal procedure fault. 



ret 



Return 



630 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(Y) 0,17 _> C(PPR.IC) 
C(Y) 18,31 _> C(IR) 



MODIFICATIONS: All except du, dl, ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



Parity 
mask 



Not BAR 
mode 



If C(Y)27 = ■ "* ' an( * ^he processor is in absolute or 
privileged mode, then ON; otherwise OFF. This indicator 
is not affected in the normal or BAR modes. 

Can be set OFF but not ON by the ret instruction 



Absolute Can be set OFF but not ON by the ret instruction 
mode 

All other If corresponding bit in C(Y) is 1, then ON; otherwise, OFF 
indicators 



NOTES: 



The relation between C(Y)-ig ->■, and the indicators is given 
in Table 4-5 earlier in this section. 

The tally runout indicator reflects C(Y) 2 5 regardless of 
what address modification is performed on the ret 
instruction. 



The ret instruction may be thought of as a ldi instruction 
followed by a transfer to location C(Y) 1 y. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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rtcd 



Return Control Double 



610 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(Y-pair) 3 17 -> C(PPR.PSR) 

Maximum of 

C(Y-pair) l8 2Q ; C(TPR.TRR); C(SDW.RI) -> C(PPR.PRR) 

C(Y-pair) 36 53 -> C(PPR.IC) 

If C(PPR.PRR) = then C(SDW.P) -> C(PPR.P); 
otherwise -> C(PPR.P) 

C(PPR.PRR) -> C(PRn.RNR) for n = (0, 1, ..., 7) 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



All except du, dl, ci, sc, scr 



None affected 



See Section 3 for descriptions of the various registers 
and Section 8 for a flowchart of their role in address 
preparation. 

If an access violation fault occurs when fetching the SDW 
for the Y-pair, the C(PPR.PSR) and C(PPR.PRR) are not 
altered. 

If the rtcd instruction is executed with the processor in 
absolute mode with bit 29 of the instruction word set OFF 
and without indirection through an itp or its pair, then: 

appending mode is entered for address preparation for 
the rtcd operand and is retained if the instruction 
executes successfully, 

and the effective segment number generated for the 
SDW fetch and subsequent loading into C(TPR.TSR) is 
equal to C(PPR.PSR) and may be undefined in absolute 
mode, 

and the effective ring number loaded into C(TPR.TRR) 
prior to the SDW fetch is equal to C(PPR.PRR) (which 
is in absolute node) implying that control is 
always transferred into ring 0. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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teo 



Transfer on Exponent Overflow 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1) 

If exponent overflow indicator ON then 
C(TPR.CA) -> C(PPr'iC) 
C(TPR.TSR) -> C(PPR.PSR) 

otherwise, no change to C(PPR) 

MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



614 (0) 



Exponent Set OFF 
overflow 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



teu 



Transfer on Exponent Underflow 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: If exponent underflow indicator ON then 

C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 
otherwise, no change to C(PPR) 

MODIFICATIONS: All except du, dl, ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



615 (0) 



Exponent Set OFF 
underflow 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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tini 



Transfer on Minus 



604 (0) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: If negative indicator ON then 

C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 
otherwise, no change to C(PPR) 

MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



tmoz 



Transfer on Minus or Zero 



604 (1) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: If negative or zero indicator ON then 

C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR-PSR) 
otherwise, no change to C(PPR) 

MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



tnc 



Transfer on No Carry 



602 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 
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SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



If carry indicator OFF then 
C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 

otherwise, no change to C(PPR) 

All except du, dl, ci, sc, scr 
None affected 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



tnz 



Transfer on Nonzero 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: If zero indicator OFF then 

C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 
otherwise, no change to C(PPR) 

MODIFICATIONS: All except du, dl, ci , sc, scr 



INDICATORS: 



None affected 



601 (0> 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



tov 



Transfer on Overflow 



617 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1) 

If overflow indicator ON then 

C(TPR.CA) -> C(PPR.IC) 

C(TPR.TSR) -> C(PPR.PSR) 
otherwise, no change to C(PPR) 
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MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Overflow Set OFF 



NOTES: 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or rpl 



tpl 



Transfer on Plus 



605 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: If negative indicator OFF, then 

C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 
otherwise, no change to C(PPR) 

MODIFICATIONS: All except du, dl , ci, sc , scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



tpnz 



Transfer on Plus and Nonzero 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

If negative and zero indicators are OFF then 

C(TPR.CA) -> C(PPR.IC) 

C(TPR.TSR) -> C(PPR.PSR) 
otherwise, no change to C(PPR) 



605 (1) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 
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NOTES : 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



tra 



Transfer Unconditionally 



FORMAT: 



710 (0) 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 



MODIFICATIONS: All except du, dl , ci, sc , scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



trc 



Transfer on Carry 



603 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1) 

If carry indicator ON then 

C(TPR.CA) -> C(PPR.IC) 

C(TPR.TSR) -> C(PPR.PSR) 
otherwise, no change to C(PPR) 



MODIFICATIONS: All except du, dl, ci, sc , scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



trtf 



Transfer on Truncation Indicator OFF 



601 (1) 



FORMAT: 



Basic instruction format (see Figure 4-1) 
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SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



If truncation indicator OFF then 
C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 

otherwise, no change to C(PPR) 

All except du, dl, ci, sc, scr 
None affected 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



trtn 



Transfer on Truncation Indicator ON 



600 (1) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1) 

If truncation indicator ON then 

C(TPR.CA) -> C(PPR.IC) 

C(TPR.TSR) -> C(PPR.PSR) 
otherwise, no change to C(PPR) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Truncation Set OFF 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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tspO 


Transfer and Set Pointer Register 


270 (0) 


tspl 


Transfer and Set Pointer Register 1 


271 (0) 


tsp2 


Transfer and Set Pointer Register 2 


272 (0) 


tsp3 


Transfer and Set Pointer Register 3 


273 (0) 


tsp4 


Transfer and Set Pointer Register 4 


670 (0) 


tsp5 


Transfer and Set Pointer Register 5 


671 (0) 


tsp6 


Transfer and Set Pointer Register 6 


572 (0) 


tsp7 


Transfer and Set Pointer Register 7 


673 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, . . . , or 7 as determined by operation code 

C(PPR.PRR) -> C(PRn.RNR) 

C(PPR.PSR) -> C(PRn.SNR) 

C(PPR.IC) + 1 -> C(PRn.WORDNO) 

00. ..0 -> C(PRn.BITNO) 
C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 



MODIFICATIONS: All except du, dl, ci, sc , scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



tss 



Transfer and Set Slave 



715 (0) 



FORMAT: 



SUMMARY: 



Basic instruction format (see Figure 4-1) 



C(TPR.CA) + (BAR bas.e) -> C(PPR.IC) 
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C(TPR.TSR) -> C(PPR.PSR) 



MODIFICATIONS: 



All except du, dl , ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Not BAR 
mode 

Absolute 
mode 



Set OFF (see notes below) 



Set OFF 



NOTES: 



If the tss instruction is executed with the processor- not 
in BAR mode the not BAR mode indicator is set OFF to 
enable subsequent addressing in the BAR mode. The base 
address register (BAR) is used in the address preparation 
of the transfer, and the BAR will be used in address 
preparation for all subsequent instructions until a fault 
or interrupt occurs. 

If the tss instruction is executed with the not BAR mode 
indicator already OFF, it functions as a tra instruction 
and no indicators are changed. 

If C(TPR.CA) >= (BAR bound) the transfer does not take 
place. Instead, a store fault (out of bounds) occurs. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 



tsxn 



Transfer and Set Index Register n 



70n (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



For n = 0, 1, . . . , or 7 as determined by operation code 

C(PPR.IC) + 1 -> C(Xn) 
C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 



MODIFICATIONS: 
INDICATORS: 



All except du, dl, ci, sc, scr 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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ttf 



Transfer on Tally Runout Indicator OFF 



FORMAT: 
SUMMARY: 



INDICATORS: 



Basic instruction format (see Figure 4-1) 

If tally runout indicator OFF then 
CCTPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 

otherwise, no change to C(PPR) 

MODIFICATIONS: All except du, dl, ci, sc, scr 



None affected 



607 (0) 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



ttn 



Transfer on Tally Runout Indicator ON 



INDICATORS: 



606 (1) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: If tally runout indicator ON then 

C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 
otherwise, no change to C(PPR) 

MODIFICATIONS: All except du, dl, ci, sc , scr 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



tze 



Transfer on Zero 



600 (0) 



F0 RMAT : 



Basic instruction format (see Figure 4-1) 
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SUMMARY: If zero indicator ON then 

C(TPR.CA) -> C(PPR.IC) 
C(TPR.TSR) -> C(PPR.PSR) 
otherwise, no change to C(PPR) 

MODIFICATIONS: All except du, dl, ci, sc, scr 

INDICATORS: None affected 

NOTES: Attempted repetition with the rpt, rpd, or rpl 

' instructions causes an illegal procedure fault. 
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POINTER REGISTER INSTRUCTIONS 



Pointer Register Data Movement Load 



easpO 


Effective Address to Segment Number of Pointer Register 


311 (0) 


easpl 


Effective Address to Segment Number of Pointer Register 1 


310 (1) 


easp2 


Effective Address to Segment Number of Pointer Register 2 


313 CO) 


easp3 


Effective Address to Segment Number of Pointer Register 3 


312 (1) 


easp4 


Effective Address to Segment Number of Pointer Register 4 


331 (0) 


easp5 


Effective Address to Segment Number of Pointer Register 5 


330 (1) 


easp6 


Effective Address to Segment Number of Pointer Register 6 


333 (0) 


easp7 


Effective Address to Segment Number of Pointer Register 7 


332 (1) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



For n = 0, 1, ..., or 7 as determined by operation code 
C(TPR.CA) -> C(PRn.SNR) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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eawpO 


Effective Address to Word/Bit Number of Pointer Register 


310 (0) 


eawpl 


Effective Address to Word/Bit Number of Pointer Register 1 


311 (1) 


eawp2 


Effective Address to Word/Bit Number of Pointer Register 2 


312 (0) 


eawp3 


Effective Address to Word/Bit Number of Pointer Register 3 


313 (D 


eawp4 


Effective Address to Word/Bit Number of Pointer Register 4 


330 (0) 


eawp5 


Effective Address to Word/Bit Number of Pointer Register 5 


331 (1) 


eawpG 


Effective Address to Word/Bit Number of Pointer Register 6 


332 (0) 


eawp7 


Effective Address to Word/Bit Number of Pointer Register 7 


333 (D 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, ..., or 7 as determined by operation code 
C(TPR.CA) -> C(PRn.WORDNO) 
C(TPR.TBR) -> C(PRn.BITNO) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



4-125 



AL39 



POINTER REGISTER DATA MOVEMENT LOAD 



epbpO 


Effective Pointer at Base to Pointer Register 


350 (1) 


epbpl 


Effective Pointer at Base to Pointer Register 1 


351 (0) 


epbp2 


Effective Pointer at Base to Pointer Register 2 


352 (1) 


epbp3 


Effective Pointer at Base to Pointer Register 3 


353 (0) 


epbp4 


Effective Pointer at Base to Pointer Register 4 


370 (1) 


epbp5 


Effective Pointer at Base to Pointer Register 5 


371 (0) 


epbp6 


Effective Pointer at Base to Pointer Register 6 


372 (1) 


epbp7 


Effective Pointer at Base to Pointer Register 7 


373 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

For n s 0, 1, ..., or 7 as determined by operation code 
C(TPR.TRR) -> C(PRn.RNR) 
C(TPR.TSR) -> C(PRn.SNR) 
00... -> C(PRn.WORDNO) 
0000 -> C(PRn.BITNO) 



MODIFICATIONS: All except du, dl , ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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eppO 


Effective Pointer to Pointer Register 


350 (0) 


eppl 


Effective Pointer to Pointer Register 1 


351 (1) 


epp2 ■ 


Effective Pointer to Pointer Register 2 


352 (0) 


epp3 


Effective Pointer to Pointer Register 3 


353 (D 


epp4 


Effective Pointer to Pointer Register 4 


370 (0) 


epp5 


Effective Pointer to Pointer Register 5 


371 (1) 


epp6 


Effective Pointer to Pointer Register 6 


372 (0) 


epp7 


Effective Pointer to Pointer Register 7 


373 (1) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, • . . , or 7 as determined by operation code 
C(TPR.TRR) -> C(PRn.RNR) 
C(TPR.TSR) -> C(PRn.SNR) 
C(TPR.CA) -> C(PRn.WORDNO) 
C(TPR.TBR) -> C(PRn.BITNO) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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lpri 



Load Pointer Registers from ITS Pairs 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



173 (0) 



Basic instruction format (see Figure 4-1). 

For n = 0, 1 , ... , 7 

Y-pair = Y-blockl6 + 2n 

Maximum of 

C(Y-pair) 18)20 ; C(SDW.R1); C(TPR.TRR) -> C(PRn.RNR) 

C( Y-pair) 3>17 -> C(PRn.SNR) 

C(Y-pair) 36>53 -> C(PRn.WORDNO) 

C(Y-pair) 5?j62 -> C(PRn.BITNO) 

All except du, dl , ci f sc, scr 

None Affected 



Starting at location Y-blockl6, the contents of eight word 
pairs (in its pair format) replace the contents of pointer 
registers through 7 as shown. 

Since C(TPR.TRR) and C(SDW.RI) are both equal to zero in 
absolute mode, C(Y-pair),o 2Q are loaded into PRn.RNR in 
absolute mode. \a,*u 

Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



lprpn 



Load Pointer Register n Packed 



FORMAT: 
SUMMARY: 



76n (0) 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, . . . , or 7 as determined by operation code 

C(TPR.TRR) -> C(PRn.RNR) 

If C(Y) , i 11, then 

C(Y) ' 5 -> C(PRn.BITNO); 
otherwise, generate command fault 

If C(Y) 6 17 = 11. ..1, then 111 -> C(PRn.SNR) n ? 
otherwise, 000 -> C(PRn.SNR) Q 2 ,c 

C(Y) 6j17 -> C(PRn.SNR) 3 14 
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MODIFICATIONS: 

INDICATORS: 

NOTES: 



C(Y) 18,35 _> C(PRn.WORDNO) 
All except du, dl, ci, sc, scr 



None affected 



Binary Is in C(Y) -i correspond to an illegal BITNO, that 
is, a bit position' beyond the extent of C(Y). Detection 
of these bits causes a command fault. 

Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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Pointer Register Data Movement Store 



spbpO 



spbpl 



spbp2 



spbp3 



spbpl 



spbp5 



spbp6 



spbp7 



Store Segment Base Pointer of Pointer Register 



Store Segment Base Pointer of Pointer Register 1 



Store Segment Base Pointer of Pointer Register 2 



Store Segment Base Pointer of Pointer Register 3 



Store Segment Base Pointer of Pointer Register 4 



Store Segment Base Pointer of Pointer Register 5 



Store Segment Base Pointer of Pointer Register 6 



Store Segment Base Pointer of Pointer Register 7 



250 (1) 



251 (0) 



252 (1) 



253 (0) 



650 (1) 



651 (0) 



652 (1) 



653 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



For n = 0, 1, . . . , or 7 as determined by operation code 

C(PRn.SNR) -> C(Y-pair) 3 17 

C(PRn.RNR) -> C(Y-pair) l8 2Q 
000 -> C(Y-pair) Q 2 
00... -> C(Y^pair) 21 29 
(43) 8 -> C(Y-pair) 30>35 
00. ..0 -> C(Y-pair) 36 71 



MODIFICATIONS: 



All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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spri 



Store Pointer Registers as ITS Pairs 



254 (0) 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



Basic instruction format (see Figure 4-1) 

For n s 0, 1, ..., 7 

Y-pair = Y-block16 + 2n 
000 -> C(Y-pair) 2 
C(PRn.SNR) -> C(Y-pair) 3 17 
C(PRn.RNR) -> C(Y-pair) l8 20 
00... -> C(Y-pair) 21 2g 
(43) 8 -> C(Y-pair) 30f35 
C(PRn.WORDNO) -> C(Y-pair) 36 53 
000 -> C(Y-pair) 54>56 
C(PRn.BITNO) -> C(Y-pair) 57 62 
00... -> C(Y-pair) 63 71 

All except du, dl, ci, sc, scr 

None affected 



Starting at location Y-blockl6, the contents of pointer 
registers through 7 replace the contents of eight word 
pairs (in its pair format). 

Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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spri-0 


Store Pointer Register as ITS Pair 


250 (0) 


spril 


Store Pointer Register 1 as ITS Pair 


251 CD- 


spri2 


Store Pointer Register 2 as ITS Pair 


252 (0) 


spri3 


Store Pointer Register 3 as ITS Pair 


253 (D 


spri4 


Store Pointer Register 4 as ITS Pair 


650 (0) 


spri5 


Store Pointer Register 5 as ITS Pair 


651 (1) 


spri6 


Store Pointer Register 6 as ITS Pair 


652 (0) 


spri7 


Store Pointer Register 7 as ITS Pair 


653 (D 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

For n = 0, 1, . . . , or 7 as determined by operation code 
000 -> C(Y-pair) 2 
C(PRn.SNR) -> C(Y-pair) 3 1? 
C(PRn.RNR) -> C(Y-pair)-, 8 20 
00... -> C(Y-pair) 21 2g 
(43) 3 -> C(Y-pair) 30>35 
C(PRn.WORDNO) -> C(Y-pair) 36 53 
000 -> C(Y-pair) 51 , 56 
C(PRn.BITNO) -> C(Y-pair) 57 62 
00. ..0 -> C(Y-pair) 63 71 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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POINTER REGISTER DATA MOVEMENT STORE 



sprpn 



Store Pointer Register n Packed 



54n (0). 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



For n = 0, 1 1 . . . , or 7 as determined by operation code 
C(PRn.BITNO) -> C(Y) 5 
C(PRn.SNR) 3 14 -> C(Y) 617 
C(PRn.WORDNO) -> C(Y) 1fi 35 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



If C(PRn.SNR) 2 are nonzero, and C(PRn.SNR) 4 11. ..1, 
then a store fault (illegal pointer) will occur and C(Y) 
will not be changed. 

Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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POINTER REGISTER ADDRESS ARITHMETIC. 



Pointer Register Address Arithmetic 



adwpO 



adwpl 



adwp2 



adwp3 



adwp4 



adwp5 



adwp6 



adwp7 



Add to Word Number of Pointer Register 



Add to Word Number of Pointer Register 1 



Add to Word Number, of Pointer Register 2 



Add to Word Number of Pointer Register 3 



Add to Word Number of Pointer Register 4 



Add to Word Number of Pointer Register 5 



Add to Word Number of Pointer Register 6 



Add to Word Number of Pointer Register 7 



050 (0) 



051 (0) 



052 (0) 



053 (0) 



150 (0) 



151 (0) 



152 (0) 



153 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



For n = 0, 1, . . . , or 7 as determined by operation code 
C(Y) 0>17 + C(PRn.WORDNO) -> C(PRn.WORDNO) 
00... -> C(PRn.BITNO) 



MODIFICATIONS: All except dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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POINTER REGISTER MISCELLANEOUS 



Pointer Register Miscellaneous 



epaq 



Effective Pointer to AQ 



213 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



MODIFICATIONS: 
INDICATORS: 



000 -> C(AQ) 02 
C(TPR.TSR) -> C(AQ) 317 
00. ..0 -> C(AQ) 18)32 
C(TPR.TRR) -> C(AQ) 33f 3 5 
C(TPR.CA) -> C(AQ) 36>53 
00. ..0 -> C(AQ) 54>65 
C(TPR.TBR) -> C(AQ)66,71 

All except du, dl, ci, sc, scr 
(Indicators not listed are not affected) 



Zero 



If C(AQ) = 0, then ON; otherwise OFF 



NOTES: 



Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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CALENDAR CLOCK 



MISCELLANEOUS INSTRUCTIONS 



Calendar Clock 



reel 



Read Calendar Clock 



633 (0) 



FORMAT: 



Basic Instruction format (see Figure 4-1), 



SUMMARY: 

MODIFICATIONS: 
INDICATORS: 



00. ..0 -> C(AQ) 0>19 

CCcalendar clock) -> C(AQ) 2 n jf 

All except du, dl, ci, sc, scr 

None affected 



NOTES: 



C(TPR.CA) 2 (CdPR.CA)! 2 for the DPS 8m processor) specify 
which processor port (i.e., which system controller) is to 
be used. The contents of the clock in the designated system 
controller replace the contents of the AQ-register. 

Attempted execution in BAR mode causes an illegal procedure 
fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



2/82 
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DERAIL 



Derail 




FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 1-1). 



Causes a fault which fetches and executes, in absolute 
mode, the instruction pair at main memory location 
C+(14)g. The value of C is obtained from the FAULT VECTOR 
switches on the processor configuration panel . 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



All, but none affect instruction execution 



None affected 



Except for the different constant used for fetching the 
instruction pair from main memory, the drl instruction is 
identical to the mme instruction. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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UTE 



ute 



iC 



Execute 



716 (0) 



FORMAT: 

SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

NOTES: 



Basic instruction format (see Figure 4-1) 



Fetch and execute the instruction in C(Y) 



All except du, dl, ci, so, scr 



None affected 



The xec instruction itself does not affect any indicator. 
However, the execution of the instruction from C(Y) may 
affect indicators. 

If the execution of the instruction from C(Y) modifies 
C(PPR.IC), then a transfer of control occurs; otherwise, 
the next instruction to be executed is fetched from 
C(PPR.IC)+1. 

To execute a rpd instruction, the xec instruction must be 
in an odd location. The instruction pair repeated is that 
instruction pair at C(PPR.IC)+1, that is, the instruction 
pair immediately following the xec instruction. C(PPR.IC) 
is adjusted during the execution of the repeated 
instruction pair so that the next instruction fetched for 
execution is from the first word following the repeated 
instruction pair. 

EIS multiword instructions may be executed with the xec 
instruction but the required operand descriptors must be 
located immediately after the xec instruction, that is, 
starting at C(PPR.IC)+1. C(PPR.IC) is adjusted during 
execution of the EIS multiword instruction so that the 
next instruction fetched for execution is from the first 
word following the EIS operand descriptors. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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EXECUTE 



xed 



Execute Double 



717 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 

MODIFICATIONS: 

INDICATORS: 



Fetch and execute the instruction pair at C(Y-pair) 



All except du, dl, ci, sc, scr 



None affected 



NOTES: 



The xed instruction itself does not affect any indicator. 
However, the execution of the instruction pair from C(Y-pair) 
may affect indicators. 

The even instruction from C(Y-pair) must not alter 
C(Y-pair)^6 f-\, and must not be another xed instruction. 

If the execution of the instruction pair from C(Y-pair) 
alters C(PPR.IC), then a transfer of control occurs; 
otherwise, the next instruction to be executed is fetched 
from C(PPR.IC)+1. If the even instruction from C(Y-pair) 
alters C(PPR.IC), then the transfer of control is effective 
immediately and the odd instruction is not executed. 

To execute an instruction pair having an rpd instruction 
as the odd instruction, the xed instruction must be located 
at an odd address. The instruction pair repeated is that 
instruction pair at C(PPR.IC)+1, that is, the instruction 
pair immediately following the xed instruction. C(PPR.IC) 
is adjusted during the execution of the repeated instruction 
pair so the the next instruction fetched for execution is 
from the first word following the repeated instruction pair. 

The instruction pair at C(Y-pair) may cause any of the 
processor defined fault conditions, but only the directed 
faults (0,1,2,3) and the access violation fault may be 
restarted successfully by the hardware. Note that the 
software induced fault tag (1,2,3) faults cannot be properly 
restarted. 

An attempt to execute an EIS multiword instruction causes 
an illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



2/82 
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MASTER MODE ENTRY 



Master Mode Entry 



mme 



Master Mode Entry 



001 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 1-1), 



Causes a fault that fetches and executes, in absolute 
mode, the instruction pair at main memory location C+4 . 
The value of C is obtained from the FAULT VECTOR switches 
on the processor configuration panel. 



MODIFICATIONS: 
INDICATORS: 



All, but none affect instruction execution 



None affected 



NOTES: 



Execution of the mme instruction implies the following 
conditions: 

During the execution of the mme instruction and the 
two instructions fetched, the processor is 
temporarily in absolute mode independent of the value 
of the absolute mode indicator. The processor stays 
in absolute mode if the absolute mode indicator is ON 
after the execution of the instructions. 

The instruction at C+4 must not alter the contents of 
main memory location C+5, and must not be an xed 
instruction. 

If the contents of the instruction counter (PPR.IC) 
are changed during execution of the instruction pair 
at C+4, the next instruction is fetched from the 
modified C(PPR.IC); otherwise, the next instruction 
is fetched from C(PPR.IC)+1. 

If the instruction at C+4 alters C(PPR.IC), then this 
transfer of control is effective immediately, and the 
instruction at C+5 is not executed. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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MASTER MODE ENTRY 



mme2 



Master Mode Entry 2 



004 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 



Causes a fault that fetches and executes, in absolute 
mode, the instruction pair at main memory location 
C+(52)g. The value of C is obtained from the FAULT VECTOR 
switches on the processor configuration panel. 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



All, but none affect instruction execution 



None affected 



Attempted execution in 
procedure fault. 



BAR mode causes an illegal 



Except for the different constant used for fetching the 
instruction pair from main memory, the mme2 instruction is 
identical to the mme instruction. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 



mme 3 



Master Mode Entry 3 



005 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1) 



Causes a fault that fetches and executes, in absolute 
mode, the instruction pair at main memory location 
C+(54)g. The value of C is obtained from the FAULT VECTOR 
switches on the processor configuration panel. 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



All, but none affect instruction execution 



None affected 



Attempted execution 
procedure fault. 



in BAR mode causes an illegal 



Except for the different constant used for fetching the 
instruction pair from main memory, the mme3 instruction is 
identical to the mme instruction. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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MASTER MODE ENTRY 



mme4 



Master Mode Entry 4 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



007 (0) 



Basic instruction format (see Figure 4-1) 



Causes a fault that fetches and executes, in absolute 
mode, the instruction pair at main memory location 
C+(56) & . The value of C is obtained from the FAULT VECTOR 
switches on the processor configuration panel. 

All, but none affect instruction execution 



None affected 



Attempted execution 
procedure fault. 



in BAR mode causes an illegal 



Except for the different constant used for fetching the 
instruction pair from main memory, the mme4 instruction is 
identical to the mme instruction. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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NO OPERATION 



No Operation 



nop 



No Operation 



011 (0) 



FORMAT: 

SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

NOTES: 



Basic instruction format (see Figure 4-1), 



No operation takes place 



All 



None affected (except as noted below) 



No operation takes place but address preparation is 
performed according to the specified modifier, if any. If 
modification other than du or dl is used, the computed 
addresses generated may cause faults. 

The use of indirect then tally modifiers causes changes in 
the address .and tally fields of the referenced indirect 
words and the tally runout indicator may be set ON as a 
result. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 



pulsl 



Pulse One 



012 (0) 



FORMAT: 
SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

NOTES: 



Basic instruction format (see Figure 4-1) 



No operation takes place 



All 



None affected (except as noted below) 



The pulsl instruction is identical to the nop instruction 
except that it causes certain unique synchronizing signals 
to appear in the processor logic circuitry. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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NO OPERATION 



puls2 



Pulse Two 



FORMAT: 

SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

NOTES: 



013 (0) 



Basic instruction format (see Figure 4-1) 



No operation takes place 



All 



None affected (except as noted below) 



The puls2 instruction is identical to the nop instruction 
except that it causes certain unique synchronizing signals 
to appear in the processor logic circuitry. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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Repeat 



REPEAT 



rpd 



Repeat Double 



560 (0) 



FORMAT: 









TALLY 



1 1 
7 8,9,01 



A 



8 111 



1 1 

11 



Term. Cond. 



(560) 8 



2 2 2 2 3 

6 IJLIM 



9 111 



DELTA 



Figure 4-9. Repeat Double (rpd) Instruction Word Format 



SUMMARY: 



Execute the pair of instructions at C(PPR.IC)+1 either a 
specified number of times or until a specified termination 
condition is met. 



MODIFICATIONS: 



None 



INDICATORS: 



(Indicators not listed are not affected) 



Tally 
runout 

All other 
indicators 



If C(X0) 7 = at termination, then ON; otherwise, OFF 

None affected. However, the execution of the repeated 
instructions may affect indicators. 



NOTES: 



The rpd instruction must be located in an odd main memory 
location except when accessed via the xec or xed 
instructions, in which case the xec or xed instruction 
must itself be in an odd main memory location. 

Both repeated instructions must use R or RI modifiers and 
only X1, X2, ..., X7 are permitted. For the purposes of 
this description, the even repeated instruction shall use 
X-even and the odd repeated instruction shall use X-odd. 
X-even and X-odd may be the same register. 



If C = 
otherwise 



1, then C(rpd instruction word)n -| 7 -> C(X0 
s, C(X0) is unchanged prior to execution. 



); 



The termination condition and tally fields of C(X0) 
control the repetition of the instruction pair. An 
initial tally of zero is interpreted as 256. 

The repetition cycle consists of the following steps: 

a. Execute the pair of repeated instructions 

b. 



C(X0) - - 1 -> C(X0) 7 
Modify 'C(X-even) and C(X- 



odd) as described below. 
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REPEAT 



c If C(XO) , = 0, then set the tally runout indicator 
ON and terminate. 

d. If a terminate condition has been met, then set the 
tally runout indicator OFF and terminate. 

e. Go to step a. 

If a fault occurs during the execution of the instruction 
pair, the repetition loop is terminated and control passes 
to the instruction pair associated with the fault 
according to the conditions for the fault. C(X0) , 
C(X-even), and C(X-odd) are not updated for the repetition 
cycle in which the fault occurs. Note in particular that 
certain faults occurring during execution of the even 
instruction preclude the execution of the odd instruction 
for the faulting repetition cycle. 

EIS multiword instructions cannot be repeated. All other 
instructions may be repeated except as noted for 
individual instructions or those that explicitly alter 

The computed addresses, y-even and y-odd, of the operands 
(in the case of R modification) or indirect words (in the 
case of RI modification) are determined as follows: 

For the first execution of the repeated instruction pair: 

C(C(PPR.IC)+1) 17 + C(X-even) -> y-even, 
y-even -> CtX-even) 

C(C(PPR.IC)+2) 17 + C(X-odd) -> y-odd, 
y-odd -> C(X-iodd) 

For all successive executions of the repeated instruction 
pair: 

if C(X0) 8 = 1, then C(X-even) + Delta -> y-even, 
y-even -> C(X-even); 
otherwise, C(X-even) -> y-even 

if C(X0)q = 1, then C(X-odd) + Delta -> y-odd, 
y-odd -> C(X-odd); 
otherwise, C(X-odd) -> y-odd 

C(X0)g Q correspond to control bits A and B, respectively, 
of the'rpd instruction word. 

In the case of RI modification, only one indirect 
reference is made per repeated execution. The TAG field 
of the indirect word is not interpreted. The indirect 
word is treated as though it had R modification with 
R = N. 

The bit configuration in C(X0), 1 17 defines the conditions 
for which the repetition lobp is terminated. The 
terminate conditions are examined at the completion of 
execution of the odd instruction. If more than one 
condition is specified, • the repeat terminates if any of 
the specified conditions are met. 
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REPEAT 



Bit 17 = Ignore all overflows. Do not set the 
overflow indicator and inhibit the overflow 
fault. 

Bit 17 = 1 Process overflows. If the overflow mask 
indicator is ON, then set the overflow 
indicator and terminate; -otherwise, cause 
an overflow fault. 

Bit 16 = 1 Terminate if the carry indicator is OFF. 

Bit 15 = 1 Terminate if the carry indicator is ON. 

Bit 14 = 1 Terminate if the negative indicator is OFF. 

Bit 13=1 Terminate if the negative indicator is ON. 

Bit 12 = 1 Terminate if the zero indicator is OFF. 

Bit 11=1 Terminate if the zero indicator is ON. 



At the time of termination: 

C(XO) -j contain the tally residue; that is, the 
number' of repeats remaining until a tally runout 
would have occurred. 

If the rpd instruction is interrupted (by any fault) 
before termination, the tally runout indicator is 
OFF. 

C(X-even) and C(X-odd) contain the computed addresses 
of the next operands or indirect words that would 
have been used had the repetition loop not 
terminated. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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REPEAT 



rpl 



Repeat Link 



500 (0) 



FORMAT: 








TALLY 



11 

7 8 9 1 







2 1 



1 1 
78 



Term. Cond. 



(500) 8 



2 2 2 2 3 
6 7 a go 



9 111 







Figure 4-10. Repeat Link (rpl) Instruction Word. Format 



SUMMARY: 



Execute the instruction at C(PPR.IC)+1 either a specified 
number of times or until a specified termination condition 
is met. 



MODIFICATIONS: 



None 



INDICATORS: 



(Indicators not listed are not affected) 



Tally If C(X0) 7 = or link address 
runout termination , then ON; otherwise OFF 



C(Y) 



0,17 



at 



All other None affected. However, the execution of the repeated 
indicators instruction may affect indicators. 



NOTES: 



The repeated instruction must use an R modifier and only 
X1 , X2, ..., X7 are permitted. For the purposes of this 
description, the repeated instruction shall use Xn. 



If 



C = 1, then C(rpl instruction word)Q ^ -> C(X0); 



x± w — i , uucn is \ i y x xwoui uubiuu wui u;a 

otherwise, C(X0) is unchanged prior to executic 

The termination condition and tally fields of C(X0) 
control the repetition of the instruction. An initial 
tally of zero is interpreted as 256. 

The repetition cycle consists of the following steps: 

a. Execute the repeated instruction 

b. C(X0) 7 - 1 -> C(X0) - 
Modify 'C(Xn) as described below. 

c. If C(X0) 7 = or C(Y)g 17 = 0, then set the tally 
runout . indicator ON and terminate. 

d. If a terminate condition has been met, then set the 
tally runout indicator OFF and terminate. 

e. Go to step a. 
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If a fault occurs during the execution of the instruction, 
the repetition loop is terminated and control passes to 
the instruction pair associated with the fault according 
to the conditions for the fault. C(X0) and C(Xn) are not 
updated for the repetition cycle in which the fault 
occurs. 

EIS multiword instructions cannot be repeated. All other 
instructions may be repeated except as noted for 
individual instructions or those that explicitly alter 
C(X0) or explicitly alter the link address, C(Y) Q 1 y. 

The computed address, y, of the operand is determined as 
follows: 

For the first execution of the repeated instruction: 

C(C(PPR.IC)+1) 0j17 + C(Xn) -> y, y -> C(Xn) 

For all successive executions of the repeated instruction: 

C(Xn) -> y 

if C(y) 17 i 0, then C(y) n -> C(Xn); 
otherwise, no change to CCXn) 

C(Y) 17 is known as the link address and is the computed 
address of the next entry in a threaded list of operands 
to be referenced by the repeated instruction. 

The operand is formed as: 

(00...0) 0f17 I! C(Y) l8jP 

where p is 35 for single precision operands and 71 for 
double precision operands. 

The bit configuration in CCXO)^ j 7 and the link address, 
C(Y)q i 7 , define the conditions Tor which the repetition 
loop is terminated. The terminate conditions are examined 
at the completion of execution of the instruction. If 
more than one condition is specified, the repeat 
terminates if any of the specified conditions are met. 



C(Y) 



0,17 



Set the tally runout indicator 
terminate. 



ON and 



Bit 17 = 
Bit 17 =1 

Bit 16 = 
Bit 15 = 
Bit 14 = 
Bit 13 = 
Bit 12 = 



Ignore all overflows. Do not set the 
overflow indicator and inhibit the overflow 
fault. 

Process overflows. If the overflow mask 
indicator is ON, then set the overflow 
indicator and terminate; otherwise, cause 
an overflow fault. 

Terminate if the carry indicator is OFF. 

Terminate if the carry indicator is ON. 

Terminate if the negative indicator is OFF. 

Terminate if the negative indicator is ON. 

Terminate if the zero indicator is OFF. 
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Bit 11=1 Terminate if the zero indicator is ON. 

At the time of termination: 

C(X0) Q>7 contain the tally residue; that is, the 
number' of repeats remaining until a tally runout 
would have occurred. 

If the rpl instruction is interrupted (by any fault) 
before termination, the tally runout indicator is 
OFF. 

C(Xn) contain the last link address, that is, the 
computed address of the list word containing the last 
operand and the next link address. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



rpt 



Repeat 



520 (0) 



FORMAT: 








TALLY 



11 

7 8 9 o 1 







1 1 

JJL 



Terra. Cond. 



8 2 1 
Figure 4-11 



2 2 2 2 3 

6 7 8 Q 



(520) 8 



9 111 



Repeat (rpt) Instruction Word Format 



3 
-5, 



DELTA 



SUMMARY: 



Execute the instruction at C(PPR.IC)+1 either a specified 
number of times or until a specified termination condition 
is met. 



MODIFICATIONS: 



None 



INDICATORS: 



(Indicators not listed are not affected) 



Tally 
runout 



If C(X0) Q 7 = at termination, then ON; otherwise, OFF 



All other None affected. However, the execution of the repeated 
indicators instruction may affect indicators. 



NOTES: 



The repeated instruction must use an R or RI modifier and 
only X1, X2, ..., X7 are permitted. For the purposes of 
this description, the repeated instruction shall use Xn . 



If C 
otherwise 



1, then C(rpt instruction word) Q 17 -> C(X0); 
s, C(X0) unchanged prior to execution.' 
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The termination condition and tally fields of C(XO) 
control the repetition of the instruction. An initial 
tally of zero is interpreted as 256. 

The repetition cycle consists of the following steps: 

a. Execute the repeated instruction 



b. C(XO) 7 - 1 -> C(XO) 7 
Modify'C(Xn) as descrifie 



fy C(Xn) as descnfied below 

c. If C(X0)q 7 = 0, then set the tally runout indicator 
ON and terminate 

d. If a terminate condition has been met, then set the 
tally runout indicator OFF and terminate 

e. Go to step a 

If a fault occurs during the execution of the instruction, 
the repetition loop is terminated and control passes to 
the instruction pair associated with the fault according 
to the conditions for the fault. C(X0) and C(Xn) are not 
updated for the repetition cycle in which the fault 
occurs. 

EIS multiword instructions cannot be repeated. All other 
instructions may be repeated except as noted for 
individual instructions or those that explicitly alter 
C(X0) or explicitly alter the instruction pair containing 
the repeated instruction. 

The computed address, y, of the operand (in the case of R 
modification) or indirect word (in the case of RI 
modification) is determined as follows: 

For the first execution of the repeated instruction: 
C(C(PPR.IC)+1) 017 + C(Xn) -> y, y -> C(Xn) 

For all successive executions of the repeated instruction: 

C(Xn) + Delta -> y, y -> C(Xn); 

In the case of RI modification, only one indirect 
reference is made per repeated execution. The TAG field 
of the indirect word is not interpreted. The indirect 
word is treated as though it had R modification with 
R = N. 

The bit configuration in C(X0)i-j 17 defines the conditions 
for which the repetition lobp is terminated. The 
terminate conditions are examined at the completion of 
execution of the instruction. If more than one condition 
is specified, the repeat terminates if any of the 
specified conditions are met. 

Bit 17 = Ignore all overflows. Do not set the 
overflow indicator and inhibit the overflow 
fault. 

Bit 17 = 1 Process overflows. If the overflow mask 
indicator is ON, then set the overflow 
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REPEAT 



Bit 16 = 
Bit 15 = 
Bit 14 = 
Bit 13 = 
Bit 12 = 
Bit 11 = 



indicator and terminate; otherwise, cause 
an overflow fault. 

Terminate if the carry indicator is OFF. 

Terminate if the carry indicator is ON. 

Terminate if the negative indicator is OFF. 

Terminate if the negative indicator is ON. 

Terminate if the zero indicator is OFF. 

Terminate if the zero indicator is ON. 



At the time of termination: 

C(X0) 0> 7 contain the tally residue; that is, the 
number' of repeats remaining until a tally runout 
would have occurred . 

If the rpt instruction is interrupted (by any fault) 
before termination, the tally runout indicator is 
OFF. 

C(Xn) contain the computed address of the next 
operand or indirect word that would have been used 
had the repetition loop not terminated. 



Attempted repetition with the rpt, rpd, or 
instructions causes an illegal procedure fault. 



rpl 
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Ring Alarm Register 



sra 



Store Ring Alarm 



754 (1) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: 



0O...O -> C(Y) 0j32 
C(RALR) -> C(Y) 33 35 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 
NOTES: 



None affected 



Attempted execution in BAR mode causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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Store Base Address Register 



sbar 



Store Base Address Register 



550 (0) 



FORMAT: Basic instruction format (see Figure 4-1) 

SUMMARY: C(BAR) -> C(Y) Qt17 
MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 
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Translation 



bed 



Binary to Binary-Coded-Decimal 



505 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

Shift CCA) left three positions 

Jc(A)j /c(Y) -> 4-bit quotient plus remainder 

Shift C(Q) left six positions 

4-bit quotient -> CCQKg 35 

remainder -> C(A) 



MODIFICATIONS: 



All except ci, sc, scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If CCA) = 0, then ON; otherwise OFF 

Negative If C(A) Q = 1 before execution, then ON; otherwise OFF 



NOTES: 



The bed instruction carries out one step in an algorithm 
for the conversion of a binary number to a string of 
Binary-Coded-Decimal (BCD) digits. The algorithm requires 
the repeated short division of the binary number or last 
remainder by a set of constants C^ - 8**i x 10**(n-i) for 
i = 1, 2, ..., n with n being defined by: 

10**(n-1) <= |<binary number>| <= 10**n - 1. 

The values in the table that follows are the conversion 
constants to be used with the bed instruction. Each 
vertical column represents the set of constants to be used 
depending on the initial value of the binary number to be 
converted. The instruction is executed once per digit 
while traversing the appropriate column from top to 
bottom. 

An alternate use of the table for conversion involves the 
use of the constants in the row corresponding to 
conversion step 1. If, after each execution, the contents 
of the accumulator are shifted right 3 positions, the 
constants in the first row, starting at the appropriate 
column, may be used while traversing the row from left to 
right. 

Because there, is a limit on range, a full 36-bit word 
cannot be converted. The largest binary number that may 
be converted correctly is 2**33 -1 yielding ten decimal 
digits. 
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TRANSLATION 



Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



Step 



1 

2 

3 
4 
5 
6 
7 
8 
9 
10 



For 10**(n-1) <= |C(A)| <= 10*»n - 1 and n = 



10 



3 2 1 



8000000000 800000000 80000000 8000000 800000 80000 8000 800 80 
6400000000 640000000 64000000 6400000 640000 64000 6400 640 64 
5120000000 512000000 51200000 5120000 512000 51200 5120 512 
4096000000 409600000 40960000 4096000 409600 40960 4096 
3276800000 327680000 32768000 3276800 327680 32768 
2621440000 262144000 26214400 2621440 262144 
2097152000 209715200 20971520 2097152 
1677721600 167772160 16777216 
1342177280 134217728 
1073741824 



gtb 



Gray to Binary 



774 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1) 



SUMMARY: C(A) is converted from Gray Code to a 36-bit binary number 
MODIFICATIONS: None 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(A) = 0, then ON; otherwise OFF 
Negative If C(A) = 1, then ON; otherwise OFF 



NOTES: 



This conversion is defined by the following algorithm: 

C(A) -> C(A) 

C(A) t C(A) i _ 1 -> Clk) ± for 1 = 1,2, ..., 35 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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REGISTER LOAD 



lbar 



Load Base Address Register 



230 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1), 



SUMMARY: 



C(Y) 0,17 -> C < BAR > 
MODIFICATIONS All except ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 

Attempted execution in BAR mode causes a illegal procedure 
fault. 



2/82 



4-157 



AL39B 



PRIVILEGED - REGISTER LOAD 



PRIVILEGED INSTRUCTIONS 



Privileged - Register Load 



lcpr 



Load Central Processor Register 



674 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 
MODIFICATIONS: 



Load selected register as noted 

None. The instruction word TAG field is used for register 
selection as follows: 

C(TAG) Data and Register(s) 

02 C(Y) -> C(cache mode register) 
04 C(Y) -> C(mode register) 

03 DPS/L68 processors: 

00... -> C(CU, OU, DU, and APU history 
register) 71 

DPS 8M processors: 

00... -> C(CU, OU/DU, APU #1 and APU #2 history 

register) 0>7 i 

07 DPS/L68 processors: 

11... 1 -> C(CU, OU, DU, and APU history 
register) 71 

DPS 8M processors: 

11... 1 -> C(CU, OU/DU, APU #1 and APU #2 history 

register) 0f71 



INDICATORS: 



None affected 



NOTES: 



See Section 3 for descriptions and use of the various 
registers. 



2/82 



4-157.1 



AL39B 



PRIVILEGED 



REGISTER LOAD 



For TAG values 03 and 07, the history register loaded is 
selected by the current value of a cyclic counter for each 
unit. All four cyclic counters are advanced by one count 
for each execution of the instruction. 

Use of TAG values other than those defined above causes an 
illegal procedure fault. 

Attempted execution in normal or BAR modes causes a 
illegal procedure fault. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 



ldbr 



Load Descriptor Segment Base Register 



232 (0) 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



Basic instruction format (see Figure 4-1). 

If SDWAM is enabled, then 

-> C ( SDWAM (i). FULL) for i = 0, 1, .... 15 
i -> C(SDWAMU).USE) for i = 0, 1 , . . . , 15 

If PTWAM is enabled, then 

-> C(PTWAMU).FULL) for i = 0, 1 15 

i -> C(PTWAMU).USE) for i = 0, 1, ..., 15 

If cache is enabled, reset all cache column and level full 
flags 

C(Y-pair) Q 23 -> C(DSBR.ADDR) 

C(Y-pair) 37 50 -> C(DSBR. BOUND) 

C(Y-pair) 55 -> C(DSBR.U) 

C(Y-pair) 60 ?1 -> CCDSBR. STACK) 

All except du, dl, ci, sc, scr 

None affected 



The associative memories and cache are cleared (full 
indicators reset) if they are enabled. 

See Section 3 and Section 5 for descriptions and use of 
the SDWAM, PTWAM, and DSBR. 

Attempted execution in normal or BAR modes causes an 
illegal procedure fault. 
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Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



ldt 



Load Timer Register 



FORMAT: 



637 (0) 



Basic instruction format (see Figure 4-1), 



SUMMARY: C < Y >0,26 _> C(TR) 

MODIFICATIONS: All except ci, sc, scr 



INDICATORS: None Affected 

NOTES: Attempted execution in normal or BAR modes causes a illegal 

procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



lptp 



Load Page Table Pointers 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



257 (D 



Basic instruction format (see Figure 4-1). 

For i = 0, 1, . . • , 15 

m = C(PTWAMU).USE) 

C(Y-blockl6+m) 0)1l , -> C(PTWAM(m) .POINTER) 
C(Y-blockl6+m) 15f26 -> C(PTWAM(m) .PAGE) 
C(Y-blockl6+m) 27 -> C(PTWAM(m) .F) 

All except du, dl, ci, sc, scr 

None affected 

The associative memory is ignored (forced to "no match") 
during address preparation. 

See Section 3 and Section 5 for description and use of the 
PTWAM. 

This instruction is not available on the DPS 8M processor 
and attempted execution on a DPS 8M processor causes an 
illegal procedure fault. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 
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Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



lptr 



Load Page Table Registers 



173 (1) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 1-1). 

For i = 0, 1, ..., 15 

ra = C(PTWAMCi).OSE) 

C(Y-blockl6+m) 17 -> C(PTWAM(m) .ADDR) 

C(Y-blockl6+m) 29 -> C(PTWAM(m) .M) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: None affected 

NOTES: The associative memory is ignored (forced to "no match") 

during address preparation. 

See Section 3 and Section 5 for description and use of the 
PTWAM. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

This instruction is not available on the DPS 8M processor 
and attempted execution on a DPS 8M processor produces an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



Ira 



Load Ring Alarm Register 



774 (D 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: C(Y) 33 35 _> C(RALR) 

MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: None affected 

NOTES: Attempted execution in normal or BAR modes causes an illegal 

procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 
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lsdp 



Load Segment Descriptor Pointers 



FORMAT: 



Basic instruction format (see Figure 4-1). 



257 (0) 



SUMMARY: 



For i = 0, 1 , .... 15 
m = C(SDWAMU).USE) 

C(Y-blockl6+m) 1i( -> C(SDWAM(m) .POINTER) 
C(Y-blockl6+m) 17 -> C(SDWAM(m) .P) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



NOTES: 



None affected 

The associative memory is ignored (forced to "no match") 
during address preparation. 

See Section 3 and Section 5 for description and use of the 
SDWAM. 

This instruction is not available on the DPS 8M processor 
and attempted execution on a DPS 8M processor produces an 
illegal procedure fault. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



lsdr 



Load Segment Descriptor Registers 



FORMAT: 
SUMMARY: 



232 (1) 



Basic instruction format (see Figure 4-1). 

For i s 0, 1, ..., 15 
m = C(SDWAM(i).USE) 
Y-pair s Y-block32 + 2m 
C(Y-pair) 23 -> C(SDWAM(m) .ADR) 
C(Y-pair) 2 4 32 -> C(SDWAM(m).R1, R2, R3) 
C(Y-pair) 37j50 -> C(SDWAM(m) -BOUND) 
C(Y-pair) 52 5? -> C(SDWAM(m) .R, E, W, P, U, G, C) 
C(Y-pair) 58 71 -> C(SDWAM(m) .CL) 
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MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None Affected 



NOTES: 



The associative memory is ignored (forced to "no-match") 
during address preparation. 

See Section 3 and Section 5 for description and use of the 
SDWAM. 

This instruction is not available on the DPS 8M processor 
and attempted execution on a DPS 8m processor produces an 
illegal procedure fault. 

attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



rcu 



Restore Control Unit 



613 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



C(Y-block8) words to 7 -> (control unit data) 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



See Section 3 for description and use of control unit data. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 
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Privileged - Register Store 



scpr 



Store Central Processor Register 



452 (0) 



FORMAT: 

SUMMARY: 

MODIFICATIONS: 



Basic Instruction format (see Figure 1-1). 

Store selected register as noted 

None. The instruction word TAG field is used for register 
selection word as follows: 



01 
06 
10 



C(TAG) MEANING 

00 DPS/L.68 processor: 

C(AP0 history register) -> C(Y-pair) 

DPS 8M processor: 

CCAPU history register #1) -> C(Y-pair) 

C(fault register) -> C(Y-pair) 35 
00. ..0 -> C(Y-pair) 36 71 

C(mode register) -> C(Y-pair) 05 
C(caehe mode register) -> C(Y-pair)g6 71 

DPS/L68 processor: 

C(D0 history register) -> C(Y-pair) 

DPS 8M processor: 

C(APU history register #2) -> C(Y-pair) 

20 CCC0 history register) -> C(Y-pair) 

40 DPS/L68 processor: 

C(00 history register) -> C(Y-pair) 

DPS 8M processor: 

C(00/D0 history register) -> C(Y-pair) 

INDICATORS: None affected 

NOTES: See Section 3 for description and use of the various registers. 

The TAG field values shown are octal. 

For TAG values 00, 10, 20, and 40, the history register 
stored is selected by the current value of a cyclic counter 
for each unit. The individual cyclic counters are advanced 
by one count for each execution of the instruction. 

The use of TAG values other than those defined above causes 
an illegal procedure fault. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 
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scu 



Store Control Unit 



657 (0) 



FORMAT: 

SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

NOTES: 



Basic instruction format (see Figure 4-1) 



(control unit data) -> C(Y-block8) 



All except du, dl, ci, sc, scr 



None affected 



See Section 3 for description and use of control unit 
data. 

The scu instruction safe-stores control information 
required to service a fault or interrupt. The control 
unit data is not, in general, valid at any time except 
when safe-stored by the first of the pair of instructions 
associated with the fault or interrupt. 

Attempted execution in normal or BAR modes causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



sdbr 



Store Descriptor Segment Base Register 



FORMAT: 



SUMMARY: 



MODIFICATIONS: 
INDICATORS: 



Basic instruction format (see Figure 4-1). 

C(DSBR.ADDR) -> C(Y-pair) 23 

00... -> C(Y-pair) 2n 36 

C(DSBR. BOUND) -> C(Y-pair) 3? 50 

0000 -> C(Y-pair) 51 54 

C(DSBR.U) -> C(Y-pair) 55 

000 -> C(Y-pair) 565Q 

C(DSBR. STACK) -> C(Y-pair) 6£) ?1 

All except du, dl, ci, sc, scr 

None affected 



154 (0) 



NOTES: 



C(DSBR) are unchanged. 
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See Section 3 and Section 5 for description and use of the 
DSBR. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



sptp 



Store Page Table Pointers 



557 (1) 



FORMAT: 



SUMMARY: 



MODIFICATIONS: 
INDICATORS: 



Basic instruction format (see Figure 4-1). 

DPS/L68 processors: 
For i = 0, 1 , ,15 

C(PTWAM(i). POINTER) -> C(Y-blockl6+i) 14 

C(PTWAM(i).PAGE) -> C(Y-blockl6+i) 15 26 

C(PTWAMU).F) -> C(Y-blockl6+i) 27 

0000 -> C(Y-blockl6+i) 8 31 

C(PTWAM(i).0SE) -> C(Y-blockl6+i> 32 35 

DPS 8M processors: 

This instruction stores 16 words from the selected level 
(j) of the directory of the Page Table Word associative 
memory. There are four levels. 

level j is selected by C(TPR.CA) 12 13 
For i = 0,1, ...15 

C(PTWAM(i, j). POINTER) -> C(Y-blockl6+l) 0> , j, 

C(PTWAM(i,j).PAGEN0) -> C(Y-blockl6+i) 15>2 2 

0000 -> C(Y-blockl6+i) 23>26 

C(PTWAM(i, j).F) -> C(Y-blockl6+i) 27 

00 -> C(Y-blockl6+i) 28 2 g 

C(PTWAM(i,j).LRU) -> C(Y-blockl6+i) 30t 35 
All except du, dl, ci, sc, scr 

None affected 



NOTES: 



The contents of the associative memory remain unchanged. 

The associative memory is ignored (forced to "no match") 
during address preparation. 
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See Section 3 and Section 5 for description and use of the 
PTWAM. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



sptr 



Store Page Table Registers 



154 (1) 



FORMAT: 
| SUMMARY: 



MODIFICATIONS: 
INDICATORS: 



Basic instruction format (see Figure H-1). 

DPS/L68 processors: 
For i = 0, 1, . .. , 15 

C(PTWAM(i).ADDR) -> C(Y-blockl6+i) 1? 

00. ..0 -> C(Y-blockl6+i) 1g 2 g 

C(PTWAM(i).M) -> C(Y-bloekl6+i) 29 

00. ..0 -> C(Y-blockl6+i) 30 35 

DPS 8M processors: 

This instruction stores 16 words from the selected level 
(j) of the contents of the Page Table Word associative 
memory. There are four levels. 

Level j is selected by C(TPR.CA)j 2 13 

For i = 0, 1,...15 

C(PTWAM(i,j).PAGE ADDR) -> C(Y-blockl6+1 ) 0f 13 

00... -> C(Y-blockl6+i) 1it 2 8 

C(PTWAM(i, j).M -> C(Y-blockl6+i) 29 

000000 -> C(Y-bloekl6+i) 30 35 
All except du, dl, ci, sc, scr 

None affected 



NOTES: 



The contents of the associative memory are unchanged. 

The associative memory is ignored (forced to "no match") 
during address preparation. 

See Section 3 and Section 5 for description and use of the 
PTWAM. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 
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Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



ssdp 



Store Segment Descriptor Pointers 



557 (0) 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



Basic instruction format (see Figure 1-1). 

DPS/L68 processors: 
For i=0, 1, ..., 15 

C(SDWAM(i). POINTER) -> C (Y-blockl6+i ) Q 14 

00. ..0 -> C(Y-blockl6+i) 15 26 

C(SDWAM(i).F) -> C(Y-blockl6+i) 27 

0000 -> C(Y-blockl6+i) 28 31 

CCSDWAM(i).USE) -> C(Y-blockl6+i) 32 35 
DPS 8M processors: 

This instruction stores 16 words from the selected level 
(j) of the directory of the Segment Descriptor Word 
associative memory. There are four levels. 

level j is selected by C(TPR.(A) 12 13 

For i = 0, 1, ... 15 

C(SDWAM(i,j). POINTER) -> C(Y-blockl6+i ) 14 

00. ..0 -> C(Y-blockl6+i) 15 26 

C(SDWAM(i,j).F) -> C(Y-blockl6+i) 27 

00 -> C(Y-blockl6+i) 28 29 

C(SDWAM(i,j).LRU) -> C(Y-blockl6+i) 30 35 

All except du, dl, ci, sc, scr 
None affected 

The contents of the associative memory are unchanged. 

The associative memory is ignored (forced to "no match") 
during address preparation. 

See Section 3 and Section 5 for description and use of the 
SDWAM. 
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Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



ssdr 



Store Segment Descriptor Registers 



254 (D 



FORMAT: 



Basic instruction format (see Figure 4-1), 



SUMMARY: 



MODIFICATIONS: 



DPS/L.68 processors: 
For 1=0, 1, ..., 15 

Y-pair = Y-block32 + 2i 

C(SDWAM(i).ADDR) -> C(Y-pair) 0> 23 

C(SDWAM(i).R1, R2, R3) -> C(Y-pair) 2 j J> 32 

0000 -> C(Y-pair) 3 3 >3 6 

C(SDWAM(i). BOUND) -> C( Y-pair) 37> 50 

C(SDWAM(i).R, E, P, U, G, C) -> C(Y-pair) 51 >57 

C(SDWAM(i).CL) -> C(Y-pair) 58>71 
DPS 8M processors: 

This instruction stores 16 double-words from the selected 
level (j) of the directory of the Segment Descriptor Word 
associative memory. There are four levels. 

level j is selected by C(TPR.CA) •, 1 } 12 

For i = 0, 1, ... 15 

CCSDWAMU, j).ADDR) -> (Y-block32+i) f 23 

C(SDWAM(i, j).R1,R2,R3) -> C (Y-block32+i) 2i) f 32 

000 -> C(Y-block32+i) 33>35 

-> C(Y-block32+i) 36 

C(SDWAM(i,j). BOUND) -> C(Y-block32+i) 37 >50 

C(SDWAM(i, j).R,E,W,P,U,G,C) -> C(Y-block32+i) 5 , ^ 57 

C(SDWAM(i,j.).CALL LIMIT) -> C(Y-block32+i) 58f 7 , 

All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



The contents of the associative memory are unchanged. 
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The associative memory is ignored (forced to "no match") 
during address preparation. 

See Section 3 and Section 5 for description and use of the 

SDWAM. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd , or rpl instructions 
causes an illegal procedure fault. 
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Privileged - Clear Associative Memory 



camp 



Clear Associative Memory Pages 



532 (1) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

DPS/L68 processors: 
For i = 0, 1 , , 15 

-> C(PTWAM(i).F) 

(i) -> C(PTWAM(i).USE) 
DPS 8M processors: 
If the associative memory is enabled 

-> C(PTWAM.F) 

C(PTWAM.LRU) is initialized for all PTWAM registers 



MODIFICATIONS: 
INDICATORS: 



All except du , dl, ci, sc, scr 



None affected 



NOTES: 



DPS/L68 processors: 

The full/empty bit of each PTWAM register is set to 0, and 
the usage counters (PTWAM. USE) are set to their pre-assigned 
values of through 15. The remainder of C(PTWAM(i)) is 
unchanged. 

The execution of this instruction enables the PTWAM if it 
is disabled and CtTPR.CA)-^ 17 = 10. 

The execution of this instruction disables the PTWAM if 
C(TPR.CA) l6 17 = 01. 

If C(TPR.CA) 15 = 1, a selective clear of cache is executed. 
Any cache block for which the upper 14 bits of the directory 
entry equal C(PTWAM( i) . ADDR) 13 will have its full/empty 
bit set to empty. 

DPS 8M processors: 

The full/empty bit of cache PTWAM register is set to zero 
and the LRU counters are initialized. The remainder of 
the contents of the registers are unchanged. If the 
associative memory is disabled, F and LRU are unchanged. 



C(TPR.CA) 
memory. 



16 17 control disabling or enabling the 
This may be done to either or both hal 



associative 
ves. 
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PRIVILEGED - CLEAR ASSOCIATIVE MEMORY 



CdPR.CA).,^ 1i( Selection 



00 
01 
10 
1 1 



both halves 

lower half, levels C & D 
upper half, levels A & B 
both halves 



The selected portion of the associative memory is 

-disabled if C(TPR.CA) 16 1? = 01 

-enabled if C(TPRCA) 16 1? = 10 

If the associative memory is disabled, the execution of 
two instructions are required to first enable and then 
clear it. 

C(TPR.CA) 15 has no effect on the DPS 8M cache. On previous 
Multics processors this bit enabled selective cache clearing 
(see above). 

All processors: 

See Section 3 and Section 5 for description and use of the 
PTWAM. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



cams 



Clear Associative Memory Segments 



532 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



DPS/L68 processors: 
For i = 0, 1, ..., 15 

-> C(SDWAM(i).F) 

(i) -> C(SDWAM(i).USE) 
DPS 8M processors: 
If the associative memory is enabled 

-> C(SDWAM.F) 

C(SDWAM.LRU) is initialized for all PTWAM registers 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 
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NOTES: DPS/L68 processors: 



The full/empty bit of each SDWAM register is set to zero, 
and the usage counters (SDWAM. USE) are initialized to their 
pre-assigned values of through 15. The remainder of 
C(SDWAM(i)) are unchanged. 

The execution of this instruction enables the SDWAM if it 
is disabled and C(TPR.CA) 1 g 17 = 10. 

The execution of this instruction disables the SDWAM if 
C(TPR.CA) 16 1? = 01 . 

The execution of this instruction sets the full/empty bits 
of all cache blocks to empty if CCTPR.CA)^ = 1. 

DPS 8M processors: 

The full/empty bit of each SDWAM register is set to zero 
and the LRU counters are initialized. The remainder of 
the contents of the registers are unchanged. If the 
associative memory is disabled, F and LRU are unchanged. 

C(TPR.CA)jg ij control disabling or enabling the associative 
memory. This may be done to either or both halves. 

C(TPR.CA) 1 ^ 14 Selection 

00 Both halves 

01 Lower half levels C & D 

10 Upper half, levels A & B 

1 1 Both halves 

The selected portion of the associative memory is 

-disabled if C(TPR.CA) 16 1? = 01 

-enabled if C(TPR.CA) l6 17 = 10 

If the associative memory is disabled, the execution of 
two instructions are required to first enable and then 
clear it. 

CtTPR.CA)^ has no effect on the DPS 8M cache. On previous 
Multics processors this bit enabled a full cache clear 
(see above). 

All processors: 

See Section 3 and Section 5 for description and use of the 
SDWAM. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 
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Privileged - Configuration and Status 



rmcm 



Read Memory Controller Mask Register 



233 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

For the selected system controller (see NOTES): 

If the processor has a mask register assigned, then 

C(assigned mask register) -> C(AQ) 
otherwise, 00... -> C(AQ) 



MODIFICATIONS: All except du, dl, ci, sc , scr 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 
Negative 



NOTES: 



If C(AQ) = 0, then ON; otherwise OFF 
If C(AQ) = 1, then ON; otherwise OFF 

The contents of the mask register remain unchanged. 

C(TPR.CA) 2 (C(TPR.CA) 1 2 for tne DPS 8M processor) specify 
which proc'essor port (i'.e., which system controller) is 
used. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 



rscr 



Read System Controller Register 



413 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 



The final computed address, C(TPR.CA), is used to select a 
system controller and the function to be performed as follows: 



Effective 
Address 

yOOOOx 

y0001x 

y0002x 
y0012x 



Function 

C( system controller mode register) -> C(AQ) 

C( system controller configuration switches) 
-> C(AQ) 

C(mask register assigned to port 0) -> C(AQ) 

C(mask register assigned to port 1) -> C(AQ) 
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y0022x 

y0032x 

y0042x 

y0052x 

y0062x 

y0072x 

y0003x 

y0004x 

or 
y0005x 

y0006x 

or 
y0007x 

where: 



PRIVILEGED - CONFIGURATION AND STATUS 

C(mask register assigned to port 2) -> C(AQ) 
C(mask register assigned to port 3) -> C(AQ) 
C(mask register assigned to port 4) -> C(AQ) 
C(mask register assigned to port 5) -> C(AQ) 
C(raask register assigned to port 6) -> C(AQ) 
C(mask register assigned to port 7) -> C(AQ) 
C(interrupt cells) -> C(AQ) 

C(calendar clock) -> C(AQ) 

C(store unit mode register) -> C(AQ) 

y = value of C(TPR.CA) 2 (C(TPR.CA), 2 I 
for the DPS 8M processor) used to select I 
the system controller 

x = any octal digit 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



All except du, dl, ci, so, set 



None affected 



See Section 3 for description and use of the various registers. 

For computed addresses y0006x and y0007x, store unit selection 
is done by the normal address decoding function of the 
system controller. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 



rsw 



Read Switches 



231 (0) 



FORMAT: 



Basic instruction format (see Figure 4-1). 



SUMMARY: 



The final computed address, C(TPR.CA), is used to select 
certain processor switches whose settings are read into 
the A-register. 
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The switches selected are as follows: 

Effective 
Address Function 



xxxxxO 
xxxxxl 

xxxxx2 



xxxxx3 
xxxxx4 

where: 



C(data switches) -> C(A) 

C( configuration switches for ports A, B, C, D) 
-> C(A) 

DPS/L68 processors: 

00. ..0 -> C(A) c 

C( fault base switches) -> C(A)g 12 

00. ..0 -> C(A), 3 2 2 ' 

CCprocessor ID) -> C(A) 2 o 33 

Coprocessor number switches? -> CCA)^^ 35 

DPS 8M processors: 

C(Port interface, Ports A-D) -> C(A) ■> 

01 -> C(A) 4 5 

C(Fault base switches) -> C(A)* * 

1 -> CCA),, ° tl£ 

0000 -> CCA),!, 17 

111 -> C(A) 18 go 

00 -> C(A)o, i, 

1 -> CCA) ^' d£ 



23 



CCProcessor mode sw) -> CCA) 2 4 

1 -> C(A) 25 

000 -> CC5T 2 6 28 

CCProcessor speed) -> CCA) 2 g 32 

CCProcessor number switches;' -> CCA) 



33,35 



C( configuration switches for ports E, F, G, H) 
-> CCA) CDPS/L68 processors only) 

00. ..0 -> CCA) 12 

CCport interlace and size switches) -> CCA)jo 2 8 
00. ..0 -> CCA) 29 35 ' 

CDPS/L68 process6rs only) 

x = any octal digit 



MODIFICATIONS: 



All, but none affect instruction execution 



INDICATORS: 



Clndicators not listed are not affected) 



Zero If CCA) = 0, then ON; otherwise OFF 
Negative If CCA) = 1, then ON; otherwise OFF 



NOTES: 



See Section 3 for description and use of the switch data. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 
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Privileged - System Control 



cioc 



Connect I/O Channel 



015 (0) 



FORMAT: 



Basic instruction format (see Figure 1-1), 



SUMMARY: 



The system controller addressed by Y (i.e., contains the 
word at Y) sends a connect signal to the port specified by 

C(Y) 33,35- 



MODIFICATIONS: 



All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



smcm 



Set Memory Controller Mask Register 



553 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 4-1). 

For the selected system controller: 

If the processor has a mask register assigned, then 

C(AQ) -> C(assigned mask register) 
otherwise a store fault (not control) occurs. 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



C(TPR.CA) 2 (CtTPR.CA), 2 on the DPS 8M processor) specify 
which processor port (i'.e., which system controller) is 
used. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 

Attempted repetition with the rpl instruction causes an 
illegal procedure fault. 
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If the SCU is a 4MW type SCU, the illegal action code 1000 
(Not Control Port) is not used. 



smic 



Set Memory Controller Interrupt Cells 



FORMAT: 



451 ( 



D 



Basic instruction format (see Figure 4-1), 



SUMMARY: 



For 1=0, 1, ..., 15 and C(A) 35 = 0: 

if C(A) 1 = 1, then set interrupt cell i ON 

For i = 0, 1 15 and C(A), 5 = 1: 

if C(A) i = 1, then set interrupt cell 16+i ON 



MODIFICATIONS: 



All except du, dl, ci, sc, scr 



INDICATORS: 
NOTES: 



None affected 

C(TPR.CA) 2 (C(TPR.(A)« 2 on a DPS 8m processor) specify 
which processor port die., which system controller) is 
used. If the processor has no assigned mask register in 
the selected system controller, a store fault (not control) 
occurs. 

If the SCU is a 4MW type SCU, the illegal action code 1000 
(Not Control Port) is not used. 

Attempted execution in normal or BAR modes causes an illegal 
procedure fault. 



sscr 



Set System Controller Register 



057 (0) 



FORMAT: 
SUMMARY: 



Basic instruction format (see Figure 1-1). 

The final computed address, C(TPR.CA), is used to select a 
system controller and the function to be performed as follows: 

Effective 
Address Function 

yOOOOx C(AQ) -> C(system controller mode register) 

yOOOIx Reserved 

y0002x C(AQ) -> C(mask register assigned to port 0) 

y0012x C(AQ) -> C(mask register assigned to port 1) 

y0022x C(AQ) -> C(mask register assigned to port 2) 

y0032x C(AQ) -> C(mask register assigned to port 3) 

y0042x C(AQ) -> C(raask register assigned to port 4) 
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y0052x 
y0062x 
y0072x 
y0003x 



y0004x 

or 
y0005x 

y0006x 

or 
y0007x 

where: 



PRIVILEGED - SYSTEM CONTROL 

C(AQ) -> CCmask register assigned to port 5) 

C(AQ) -> CCmask register assigned to port 6) 

C(AQ) -> C(mask register assigned to port 7) 

C(AQ) i 5 -> CCinterrupt cells 0-15) 
C(AQ) 3 6 51 -> CCinterrupt cells 16-3D 

C(AQ) -> (calendar clock) 
(for 4MW SCU only) 

C(AQ) -> C(store unit mode register) 



y = 



value of C(TPR.CA) ? (C(TPR .CA) ^ 2 on 
or) 



the DPS 8M process 
the system controller 



used to select 



x s any octal digit 



MODIFICATIONS: 
INDICATORS: 



All except du, dl, ci, sc, scr 



None affected 



NOTES: 



If the processor does not have a mask register assigned in 
the selected system controller a store fault (not control) 
occurs. 

For computed addresses y0006x and y0007x, store unit selection 
is done by the normal address decoding function of the 
system controller. 

See Section 3 for description and use of the various registers. 

Attempted execution on normal or BAR modes causes an illegal 
procedure fault. 
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Privileged - Miscellaneous 



absa 



Absolute Address to A-Register 



FORMAT: 
SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

Zero 
Negative 

NOTES: 



212 (0) 



Basic instruction format (see Figure 4-1). 

Final main memory address, Y -> C(A) n 
00. ..0 -> C(A) 2J(j35 

All except du, dl, ci, sc, scr 

(Indicators not listed are not affected) 

If C(A) = 0, then ON; otherwise OFF 
If C(A) = 1, then ON; otherwise OFF 

wfirbe^ndefJned^" 00 iS " e ° Uted in abSOlute mode > C(A > 

me^rproredurrfLA". n ° rmal ° P ^ ™*°* " u "» a " 

Attempted repetition with the rpt, rpd, or rol 
instructions causes an illegal procedure fault. 



dis 



Delay Until Interrupt Signal 



FORMAT: 
SUMMARY: 

MODIFICATIONS: 

INDICATORS: 

NOTES: 



616 (0) 



Basic instruction format (see Figure 4-1). 

No operation takes place, and the processor does not 
continue with the next instruction; it wlits for a 
external interrupt signal. a 

All, but none affect instruction execution 
None affected 

fn!«? ed ex « cuti ° n in n°™al or BAR modes causes an 
illegal procedure fault. an 

Attempted repetition with the rpt, rpd, or ml 
instructions causes an illegal procedure fault. 
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EXTENDED INSTRUCTION SET (EIS) 



EIS - Address Register Load 



aarn 



Alphanumeric Descriptor to Address Register n 



56n (1) 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



EIS single-word instruction format (see Figure 4-1). 

For n a 0, 1 , . . . , or 7 as determined by operation code 

C(Y) 0,17 - y C(ARn.WORDNO) | 

If C(Y) 21>2 2 = 00 (TA code = 0). th en 

C(Y) 18,19 _> C(ARn.CHAR) I 

0000 -> C(ARn.BlTNO) | 

If C <Y) 21>2 2 = 01 < TA c °de =1), then 

(6 • C(Y) 1820 ) / 9 -> C(ARn.CHAR) I 

(6 « C(Y) 18f20 ) nod9 -> C(ARn.BITNO) | 

If C(Y) 21>2 2 ~ 10 (TA code = 2) » then 

C(Y) 18,20 / 2 -> C(ARn.CHAR) I 

4 * (C(Y) l8,20>mod2 + 1 "> C(ARn.BITNO) | 

All except du, dl, ci , sc, scr 
None affected. 

An alphanumeric descriptor is fetched from Y and C(Y) 2 i ?2 
(TA field) is examined to determine the data type 
described. 

If TA = (9-bit data), then C(Y) 1ft , Q goes to C(ARn.CHAR) I 
and zeros fill C(ARn.BITNO) . ' * | 



If TA a 1 (6-bit data) or TA = 2 (4-bit data), C(Y) 18 20 
is appropriately translated into an equivalent character 



and bit position 
C(ARn.BITNO). 



that goes to C(ARn.CHAR) 



and 



I 



If C(Y) 21 22 = 1 1 ^ TA code = 3) an illegal procedure fault 
occurs. ' 



If C(Y) 



23 



1 an illegal procedure fault occurs, 



If C(Y) 21 22 
procedure 'fai 



pr 



00 (TA code 
ault occurs. 



0) and C(Y) 



20 



1 an illegal 
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If !? n ( p21,22 = 01 < TA code = 1> and C(Y) 18 20 - 11 ° or 111 
an illegal procedure fault occurs. ' 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



larn 



Load Address Register n 



FORMAT: 
SUMMARY: 

MODIFICATIONS: 



76n (1) 



EIS single-word instruction format (see Figure 4-1). 

For n s 0, 1, . . . , or 7 as determined by operation code 
C(Y) 0t 23 -> c(ARn > 

All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



lareg 



Load Address Registers 



FORMAT: 
SUMMARY: 



463 (D 



EIS single-word instruction format (see Figure 4-1) 

For i = 0, 1 7 

C(Y-block8+i) 0> 23 _> c(ARi ^ 



MODIFICATIONS: All except du, dl, ci, sc , scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



lpl 



Load Pointers and Lengths 



467 (1) 



FORMAT: 



EIS single-word instruction format (see Figure 4-1) 



SUMMARY: 



C(Y-block8) -> C(decimal unit data) 
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MODIFICATIONS: All except du, dl, ci, sc , scr 



INDICATORS: 



None affected 



NOTES : 



See Section 3 for description and use of decimal unit 
data. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



narn 



Numeric Descriptor to Address Register n 



66n (1) 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



EIS single-word instruction format (see Figure 4-1). 

For n = 0, 1, . . . , or 7 as determined by operation code 
C(Y) 0>17 -> C(ARn.WORDNO) 
If C(Y) 21 = (TN code = 0), then 

C(Y) 18)20 -> C(ARn.CHAR) 

0000 -> C(ARn.BITNO) 
If C(Y) 21 = 1 (TN code =1), then 

(C(Y) 18>20 ) / 2 -> C(ARn.CHAR) 

4 * (C(Y) l8 ^ 20 ) mod2 + 1 -> C(ARn.BITNO) 

All except du, dl, ci, sc, scr 
None affected 



A numeric descriptor is fetched from Y and C(Y) 21 (TN bit) 
is examined. 

If TN s (9-bit data), then C(Y) 18 iq goes to C(ARn.CHAR) I 
and zeros fill C(ARn.BITNO) . ' | 

If TN = 1 (4-bit data), C(Y) 18 20 is appropriately 
translated to an equivalent character and bit position 
that goes to C(ARn.CHAR) and C(ARn.BITNO) . f 

If C(Y) 21 = (TN code = 0) and C(Y) 20 = 1 an illegal 
procedure fault occurs. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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EIS - Address Register Store 



aran 



Address Register n to Alphanumeric Descriptor 



54n (1) 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



EIS single-word instruction format (see Figure 4-1). 

For n = 0, 1, . . . , or 7 as determined by operation code 
C(ARn.WORDNO) -> C(Y) 1? 
If C(Y) 21 22 = 00 (TA code = 0), then 

C(ARn.CHAR) -> C(Y) 18 1Q 

-> C(Y) 20 

If C(Y) 21f2 2 = 01 (TA code = 1) > tnen 

(9 * C(ARn.CHAR) + C(ARn.BITNO) ) / 6 -> C(Y) 18 2Q 

If C(Y) 2 i >2 2 s 10 (TA code = 2) » then 

(9 * C(ARn.CHAR) + C(ARn.BITNO) - 1) / 4 -> C(Y) l8 20 

All except du, dl f ci, sc, scr 

None affected 



This instruction is the inverse of the aarn instruction. 

The alphanumeric descriptor is fetched from Y and 
C(Y) 2 , 2 2 (TA 
type described. 



C(Y) 2 i 22 ^ TA field ) is examined to determine the data 
*• der- -"-■■■ 



If TA = (9-bit data), C(ARn.CHAR) goes to C(Y) 18 1Q . 

If TA = 1 (6-bit data) or TA = 2 (4-bit data), C(ARn.CHAR) 
and C(ARn.BITNO) are translated to an equivalent character 
position that goes to C(Y)-| 8 2Q . 

If C(Y) 21 22 = 11 (TA code = 3) or C(Y) 23 = 1 (unused 
bit), an illegal procedure fault occurs. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



arnn 



Address Register n to Numeric Descriptor 



64n (1) 



FORMAT: 



EIS single-word instruction format (see Figure 4-1) 
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SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



EIS - ADDRESS REGISTER STORE 

For n = 0, 1, . . . , or 7 as determined by operation code 
C(ARn.WORDNO) -> C(Y) Q 17 
If C(Y) 21 = (TN code = 0), then 

C(ARn.CHAR) -> C(Y) 18 19 | 



I 



-> C(Y) 



20 



If C(Y) 21 = 1 (TN code =1), then 

(9 * C(ARn.CHAR) + C(ARn.BITNO) - 1) / 4 -> C(Y) 18j20 | 

All except du, dl, ci, sc, scr 

None affected 

This instruction is the inverse of the narn instruction. 

The numeric descriptor is fetched from Y and C(Y) 2 -| (TN 
bit) is examined. 

If TN s (9-bit data), then C(ARn.CHAR) goes to | 

C(Y) 18,19* 

If TN = 1 (4-bit data), then C(ARn.CHAR) and C(ARn.BITNO) | 
are translated to an equivalent character position that 
goes to C(Y) 1 g 20 - 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



sarn 



Store Address Register n 



7Un (1) 



FORMAT: 



EIS single-word instruction format (see Figure 4-1) 



SUMMARY: 



For n = 0, 1, . . . , or 7 as determined by operation code 
C(ARn) -> C(Y) 0f23 
00. ..0 -> C(Y) 2Uj35 



MODIFICATIONS: All except du, dl, ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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sareg 



Store Address Registers 



443 (D 



FORMAT: 



EIS single-word instruction format (see Figure 4-1) 



SUMMARY: 



For i = 0, 1 , . . .', 7 

C(ARi) -> C(Y-block8+i) 23 
00... -> C(Y-block8+i) 24 35 



MODIFICATIONS: All except du, dl , ci , sc, scr 



INDICATORS: 



None affected 



NOTES: 



Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



spl 



Store Pointers and Lengths 



447 (1) 



FORMAT: 



EIS single-word instruction format (see Figure 4-1) 



SUMMARY: 



C(decimal unit data) -> C(Y-block8) 



MODIFICATIONS: All except du, dl , ci, sc, scr 



INDICATORS: 



None affected 



NOTES: 



See Section 3 for description and use of decimal unit 
data . 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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EIS - Address Register Special Arithmetic 



a4bd 



Add 4-bit Displacement to Address Register 



502 (1) 



FORMAT: 




2 
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Figure 4-12. EIS Address Register Special Arithmetic Instruction Format 



ARn 

ADDRESS 

OPCODE 

I 
A 
REG 

SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



Number of address register selected 

Literal word displacement value 

Instruction operation code 

Interrupt inhibit bit 

Use address register contents flag 

Any register modification except du, dl, ic 

If A = 0, then 

ADDRESS + C(REG) / 4 -> C(ARn.WORDNO) 

C(REG) mod4 -> C(ARn.CHAR) 

4 * C(REG) mod2 + 1 -> C(ARn.BITNO) 

If A = 1, then 

C(ARn.WORDNO) + ADDRESS + (9 * C(ARn.CHAR) 

+ 4 * C(REG) + C(ARn.BITNO)) / 36 -> C(ARn.WORDNO) 

((9 * C(ARn.CHAR) + 4 * C(REG) + 

C(ARn.BITNO)) mod35 ) / 9 -> C(ARn.CHAR) 

4 * (C(ARn.CHAR) + 2 * C(REG) + 

C(ARn.BITNO) / 1) mod2 + 1 _> C(ARn.BITNO) 

None except au, qu, al , ql , xn 

None affected 



The steps described in SUMMARY define special 4-bit 
addition arithmetic for ADDRESS, C(REG), C( ARn .W0RDN0) , 
C(ARn.CHAR), and C(ARn.BITNO) . 
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C(REG) is always treated as a count of 4-bit characters. 

The use of an address register is inherent.; the value of 
bit 29 in the instruction word affects operand evaluation 
but not register selection. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 



a6bd 



Add 6-bit Displacement to Address Register 



501 (1) 



FORMAT: 



EIS address register special arithmetic instruction 
format (see Figure 4-12). 



SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



+ 6 * C(REG) 



If A = 0, then 

ADDRESS + C(REG) / 6 -> C(ARn.WORDNO) 
((6 » C(REG)) mod36 ) / 9 -> C(ARn.CHAR) 
(6 • C(REG)) modg -> C(ARn.BITNO) 

If A = 1, then 

C(ARn.WORDNO) + ADDRESS •► (9 * C(ARn.CHAR) 
+ C(ARn.BITNO)) / 36 -> CCARn .WORDNO) 

((9 * C(ARn.CHAR) + 6 * C(REG) + 

C(ARn.BITNO)) mod36 ) / 9 -> C(ARn.CHAR) 

(9 * CCARn. CHAR) + 6 » C(REG) + 
C(ARn.BITNO)) modg - -> C(ARn.BITNO) 

None except au, qu, al, ql, xn 

None Affected 



The steps described in SUMMARY define special 6-bit 
addition arithmetic for ADDRESS, C(REG), C(ARn .WORDNO) , 
C(ARn.CHAR), and C( ARn .BITNO) . 

C(REG) is always treated as a count of 6-bit characters. 

The use of an address register is inherent; the value of 
bit 29 in the instruction word affects address preparation 
but not register selection. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



a9bd 



Add 9-bit Displacement to Address Register 



500 (1) 
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FORMAT: 



EIS address register special arithmetic instruction 
format (see Figure 4-12). 



SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



If A = 0, then 

ADDRESS + CC.REG) / 4 -> C(ARn .WORDNO) 

C(REG) modM -> CCARn. CHAR) 

If A = 1, then 

C(ARn. WORDNO) + ADDRESS + 

(C(REG) + C(ARn.CHAR))/4 -> CCARn. WORDNO) 

(CCARn. CHAR) + C(REG)) mod4 -> CCARn. CHAR) 

0000 -> CCARn. BITNO) 

None except au, qu, al, ql, xn 

None affected 



The steps described in SUMMARY define special 9-bit 
addition arithmetic for ADDRESS, C(REG), C( ARn. WORDNO) , 
and CCARn. CHAR). 

CCREG) is always treated as a count of 9-bit bytes. 

The use of an address register is inherent; the value of 
bit 29 in the instruction word affects operand evaluation 
but not register selection. 

Attempted repetition with the rpt, rpd , or rpl 
instructions causes an illegal procedure fault. 



abd 



Add Bit Displacement to Address Register 



503 (1) 



FORMAT: 



EIS address register special arithmetic instruction 
format (see Figure 4-12). 



SUMMARY: 



If A = 0, then 

ADDRESS + CCREG) / 36 -> CCARn .WORDNO) 

CC(REG) mod36 ) / 9 -> CCARn. CHAR) 

C(REG) modQ -> CCARn. BITNO) 
If A = 1, then' 

CCARn. WORDNO) + ADDRESS + (9 * CCARn. CHAR) + 36 * CCREG) 
+ CCARn. BITNO)) / 36 -> CCARn .WORDNO) 
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MODIFICATIONS: 

INDICATORS: 

NOTES: 



((9 * C(ARn.CHAR) + 36 * C(REG) + 

C(ARn.BITNO)) mod36 ) / 9 -> C(ARn.CHAR) 

(9 * C(ARn.CHAR) + 36 * C(REG) + 
C(ARn.BITNO)) modg -> C(ARn.BITNO) 

None except au, qu , al, ql, xn 

None affected 



The steps described in SUMMARY define special bit addition 
arithmetic for ADDRESS, C(REG), C( ARn.WORDNO) , 
C(ARn.CHAR), and C( ARn .BITNO) . 

C(REG) is always treated as a bit count. 

The use of an address register is inherent; the value of 
bit 29 in the instruction word affects operand evaluation 
but not register selection. 



Attempted repetition with the rpt, rpd, or 
instructions causes an illegal procedure fault. 



rpl 



awd 



Add Word Displacement to Address Register 



507 (1) 



FORMAT: 



EIS address register special arithmetic instruction 
format (see Figure 4-12). 



SUMMARY: 



If A = 0, then 

ADDRESS + C(REG) -> C(ARn.WORDNO) 
If A = 1, then 

C(ARn.WORDNO) + ADDRESS + C(REG) ->C(ARn .WORDNO) 
00 -> C(ARn.CHAR) 
0000 -> C( ARn. BITNO) 



MODIFICATIONS: 
INDICATORS: 



None except au, qu , al, ql, xn 



None affected 



NOTES: 



The use of an address register is inherent; the value of 
bit 29 in the instruction word affects operand evaluation 
but not register selection. 

C(REG) is always treated as a word count. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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s4bd 



Subtract 4-bit Displacement from Address Register 



522 (1) 



FORMAT: 



EIS address register special arithmetic instruction 
format (see Figure 4-12). 



SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



If A = 0, then 

- (ADDRESS + C(REG) / 4) -> C(ARn.WORDNO) 

- C(REG) ffl0d4 -> C(ARn.CHAR) 

- 4 * C(REG) mod2 + 1 -> C(ARn.BITNO) 
If A = 1, then 

C(ARn.WORDNO) - ADDRESS + (9 * C(ARn.CHAR) - 4 * C(REG) 
+ C(ARn.BITNO)) / 36 -> C(ARn.WORDNO) 

((9 * C(ARn.CHAR) - 4 * C(REG) + 

C(ARn.BITNO)) mod36 ) / 9 -> C(ARn.CHAR) 

4 * (C(ARn.CHAR) - 2 * C(REG) + 

C(ARn.BITNO) / 1 ») mod2 + 1 -> C(ARn.BITNO) 

None except au, qu, al , ql, xn 

None affected 



The steps described in SUMMARY define special 4-bit 
subtraction arithmetic for ADDRESS, C(REG), C( ARn.WORDNO) , 
C(ARn.CHAR), and C(ARn .BITNO) . 

C(REG) is always treated as a count of 4-bit characters. 

The use of an address register is inherent; the value of 
bit 29 in the instruction word affects operand evaluation 
but not register selection. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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s6bd 



Subtract 6-bit Displacement from Address Register 



521 (1) 



FORMAT: 



EIS address register special arithmetic instruction 
format (see Figure 4-12). 



SUMMARY: 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



If A = 0, then 

- (ADDRESS + C(REG) / 6) -> C(ARn.WORDNO) 



- ((6 * C(REG)) 



mod 36 



) / 9 -> C(ARn.CHAR) 



- 6 * C(REG) 



- (6 « C(REG)) modQ -> C(ARn.BITNO) 
If A = 1, then 

C(ARn. WORDNO) - ADDRESS + (9 * C(ARn.CHAR) 
+ C(ARn.BITNO)) / 36 -> C(ARn .WORDNO) 

((9 * C(ARn.CHAR) - 6 * C(REG) + 

C(ARn.BITNO)) mod36 ) / 9 -> C(ARn.CHAR) 

(9 * C(ARn.CHAR) - 6 * C(REG) + 
C(ARn.BITNO)) modg -> C(ARn.BITNO) 

None except au, qu, al, ql, xn 



None Affected 



The steps described in SUMMARY define special 6-bit 
subtraction arithmetic for ADDRESS, C(REG), C(ARn. WORDNO) , 
C(ARn.CHAR), and C( ARn.BITNO) . 

C(REG) is always treated as a count of 6-bit characters. 

The use of an address register is inherent; the value of 
bit 29 in the instruction word affects operand evaluation 
but not register selection. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



s9bd 



Subtract 9-bit Displacement from Address Register 



520 (1) 



FORMAT: 



EIS address register special arithmetic instruction 
format (see Figure 4-12). 



SUMMARY: 



If A = 0, then 

- (ADDRESS + C(REG) / 4) -> C(ARn. WORDNO) 

- C(REG) modU -> C(ARn.CHAR) 
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If A = 1, then 

C(ARn. WORDNO) - ADDRESS + 

(C(ARn.CHAR) - C(REG)) / 4 -> C(ARn .WORDNO) 

(C(ARn.CHAR) - C(REG)) mod4 -> C(ARn.CHAR) 

OOOO -> C(ARn.BITNO) 



MODIFICATIONS: 
INDICATORS: 



None except au, qu, al, qu, xn 



None affected 



NOTES: 



The steps described in SUMMARY define special 9-bit 
subtraction arithmetic for ADDRESS, C(REG), C(ARn. WORDNO) , 
and C(ARn.CHAR). 

C(REG) is always treated as a count of 9-bit bytes. 

The use of an address register is inherent: the value of 
bit 29 in the instruction word affects operand evaluation 
but not register selection. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 



sbd 



Subtract Bit Displacement from Address Register 



523 (1) 



FORMAT: 



EIS address register special arithmetic instruction 
format (see Figure 4-12). 



SUMMARY: 



If A = 0, then 

- (ADDRESS + C(REG) / 36) -> C(ARn. WORDNO) 

- CC(REG) mod36 ) / 9 -> C(ARn.CHAR) 



- C(REG) 



mod9 



-> - C(ARn.BITNO) 



If A = 1, then 



C(ARn. WORDNO) - ADDRESS + (9 * C(ARn.CHAR) - 36 « C(REG) 
+ C(ARn.BITNO)) / 36 -> C(ARn. WORDNO) 

((9 * C(ARn.CHAR) - 36 * C(REG) + 

C(ARn.BITNO)) mod36 ) / 9 -> C(ARn.CHAR) 

(9 * C(ARn.CHAR) - 36 * C(REG) + 
C(ARn.BITNO)) modg -> C(ARn.BITNO) 



MODIFICATIONS: 



None except au, qu, al, ql, xn 



INDICATORS: 



None affected 
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NOTES: 



bit 



The steps described in SUMMARY define special 

2V^ ra S"S? arithraetic for ADDRESS, C(REG), C( ARn .WORDNO) " 
C(ARn.CHAR), and C( ARn .BITNO) . 

C(REG) is always treated as a bit count. 

The use of an address register is inherent; the value of 
bit 29 in the instruction word affects operand evaluation 
but not register selection. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault.' 



or 



rpl 



swd 



Subtract Word Displacement from Address Register 



FORMAT: 



527 (1) 



EIS address register special arithmetic instruction 
format (see Figure 4-12). 



SUMMARY: 



If A = 0, then 

- (ADDRESS + C(REG)) -> C(ARn. WORDNO) 
If A = 1, then 

C(ARn. WORDNO) - (ADDRESS + C(REG)) -> C( ARn .WORDNO) 
00 -> C(ARn.CHAR) 
0000 -> C(ARn. BITNO) 



MODIFICATIONS: 

INDICATORS: 

NOTES: 



None except au, qu, al , ql , 



None Affected 



xn 



The use of an address register is inherent; the value of 
bit 29 in the instruction word affects operand evaluation 
but not register selection. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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EIS - Alphanumeric Compare 



cmpc 



Compare Alphanumeric Character Strings 



FORMAT: 



106 (1) 








? 


1 

,2 o 


1 

1 




1 
7 


1 2 
8 


2 2 

1 2 


2 

3 


2 
4 


2 

7 


2 

8 


2 
9 




3 
5 


FILL 
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106 (1) 


I 


MF1 




9 2 
Y-charn1 




7 


CN1 


TA1 







10 1 

N1 




7 


Y-charn2 


CN2 
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Figure 4-13. Compare Alphanumeric Character Strings (cmpc) EIS Multiword 

Instruction Format 



FILL 

MF1 

MF2 

I 

Y-charn1 

CN1 

TA1 

N1 

Y-charn2 

CN2 

N2 



Fill character for string extension 

Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Interrupt inhibit bit 

Address of left-hand string 

First character position of left-hand string 

Data type of left-hand string 

Length of left-hand string 

Address of right-hand string 

First character position of right-hand string 

Length of right-hand string 



ALM Coding Format: 

cmpc 

descna 

descna 



SUMMARY: 



(MF1) ,(MF2) [.fill (octalexpression)] 

Y-charn1[(CN1)] ,N1 n = 4, 6, or 9 (TA1 = 2, 1, or 0) 

Y-charn2[(CN2)] ,N2 n = 4, 6, or 9 (TA2 is ignored) 



For i = 1, 2, ..., minimum (N1,N2) 

C(Y-charn1) i _ 1 :: C(Y-charn2) i _ 1 
If N1 < N2, then for i = N1+1 , N1+2, ..., N2 
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C(FILL) :: C(Y-charn2) i _ 1 



If N1 > N2, then for i = N2+1 , N2+2 Ml 

C(Y-charn1) i _ 1 :: C(FILL) 



MODIFICATIONS: 
INDICATORS: 

Zero 

Carry 



None except au, qu, al , ql, xn for MF1 and MF2 
(Indicators not listed are not affected) 

I L C(Y :° har - 1) i-1 = C(Y-charn2) l . 1 for all i, then ON: 
otherwise, OFF - j. i » 

If C(Y-charn1) i . 1 < C(Y-charn2) L _, for any i, then OFF; 
otherwise ON - 1-1 ■> > 



NOTES: 



Both strings are treated as the data type given for the 
left-hand string, TA1. A data type given for the 
right-hand string, TA2, is ignored. 

Comparison is made on full 9-bit fields. If the given 
data type is not 9-bit (TA1 i 0), then characters from 
C(Y-cnarnl) and C(Y-charn2) are high-order zero filled 
All 9 bits of C(FILL) are~used. 

Instruction execution proceeds until an inequality is 
found or the larger string length count is exhausted. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 



Attempted repetition with the rpt, rpd , 
instructions causes an illegal procedure fault. 



or 



rpl 
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scd 



Scan Characters Double 



120 (1) 



FORMAT: 







1 



1 
1 


1 

7 


1 2 
8 


2 2 
1 2 


2 
3 


2 2 
4 7 


2 

8 


2 
9 


3 3 
1 


3 3 
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00000000000 


MF2 


120 (1) 


I 


MF1 




11 
Y-charn1 




7 


CN1 


TA1 





10 1 7 
N1 


Y-charn2 


CN2 


2 1 12 
000000000000000 


Y3 


3 

00000000000 


A 





15 

REG 



18 



11 1 



Figure 4-14. Scan Characters Double (scd) EIS Multiword Instruction Format 



MF1 

MF2 

I 

Y-charn1 

CN1 

TA1 

N1 

Y-charn2 

CN2 

Y3 

A 

REG 



Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Interrupt inhibit bit 

Address of string 

First character position of string 

Data type of string 

Length of string 

Address of test character pair 

First character position of test character pair 

Address of compare count word 

Indirect via pointer register flag for Y3 

Register modifier for Y3 



ALM Coding Format: 

scd (MF1),(MF2) 

descna Y-charn1 [(CN1 )] ,N1 

descna Y-charn2[(CN2) ] 

arg Y3[,tag] 



n = 4, 6, or 9 (TA1 = 2, 1, or 0) 
n = 4, 6, or 9 (TA2 is ignored) 



SUMMARY: 



For i = 1, 2, .... N1-1 

C(Y-charn1) i _ 1 ^ :: C(Y-charn2) 1 
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On instruction completion, if a match was found; 

00. . .0 -> C(Y3) n 

i_1 _> c(Y3) 12t35 
If no match was found: 

00. ..0 -> C(Y3) n 

N1-1 -> C(Y3) 12> 35 



MODIFICATIONS: 



None except au, qu, al, ql, xn for MF1 and REG 
None except du, au, qu, al, ql, xn for MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Tally If the string length count is exhausted without a match, 
runout or if N1 = 1, then ON; otherwise OFF 



NOTES: 



Both the string and the test character pair are treated as 
the data type given for the string, TA1. A data type 
given for the test character pair, TA2, is ignored. 

Instruction execution proceeds until a character pair match 
is found or the string length count is exhausted. 

If MFk.RL = 1, then Nk does not contain the operand length; 
instead, it contains a register code for a register holding 
the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

If MF2.ID = and MF2.REG = du, then the second word following 
the instruction word does not contain an operand descriptor 
for the test character pair; instead, it contains the test 
character pair as a direct upper operand in bits 0, 17. 

Attempted execution with the xed instruction causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 



scdr 



Scan Characters Double in Reverse 



121 (1) 



FORMAT: 



Same as Scan Characters Double (scd) format 
(see Figure 4-14). 



SUMMARY: 



For i= 1, 2, ..., N1-1 

C(Y-charn1 ) N1 _ 1 _ 1 (j1-i :: C(Y-charn2) n 1 
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On instruction completion, if a match was found: 

00. ..0 -> C(Y3) n 

i_1 _> c(Y3) 12>3 5 
If no match was found: 

00. ..0 -> C(Y3) 1, 

N1-1 -> C(Y3) 12 ,35 

MODIFICATIONS: N T one except au, qu, al, ql, xn for MF1 and REG 
none except du, au, qu, al, ql, xn for MF2 

iNDtCATORS: (Indicators not listed are not affected) 

Tally If the string length count is exhausted without a match, 
runout or if N1 = 1, then ON; otherwise OFF 

MOTES: Both the string and the test character pair are treated as 

the data type (riven for the string, TA1. A data type 
given for the test character pair, TA2, is ignored. 

Instruction execution proceeds until a character pair match 
is found or the string length count is exhausted. 

If MFk.RL = 1, then Mk does not contain the operand length; 
instead, it contains a register code for a register holding 
the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

If MF2.ID = and MF2.REG = du, then the second word following 
the instruction word does not contain an operand descriptor 
for the test character pair; instead, it contains the test 
character pair as a direct upper operand in bits 0,17. 

Attempted execution with the xed instruction causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 
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Scan with Mask 



124 (1) 



FORMAT: 










8 


1 
9 


1 1 
1 7 


1 2 
3 


2 2 
1 2 


2 
3 


2 2 

4 7 


2 
3 


2 


3 3 
1 


3 3 
2 
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I 
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7 
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Ml 
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15 
REG 



MASK 



13 
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11 1 



Figure 4-15- Scan with Mask (sera) EIS Multiword Instruction Format 



MF 1 

MF2 

I 

Y-charn1 

CN1 

TA1 

N1 

Y-charn2 

CN2 

Y3 

A 

REG 



?4odif ication field for operand descriptor 1 

Modification field for operand descriptor 2 

Interrupt inhibit bit 

Address of string 

First character position of string 

Data type of string 

Length of string 

Address of test character 

First character position of test character 

Address of compare count wofd 

Indirect via pointer register flag for Y3 

Register modifier for Y3 



ALM Coding Format: 

sera (MF1),(MF2)[,mask(octalexprsssion)] 

descna Y-charnl [ ( CN 1 ) ] , N1 n = 4, 6, or 9 (TA1 = 2, 1, or 0) 

descna Y-charn2[ ( CN2) ] n = 4, 6, or 9 (TA2 is ignored) 

arg " Y3[ , tag] 



SUMMARY: 



For characters i = 1, 2, 



N1 
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For bits j = 0, 1 , 



MODIFICATIONS: 



INDICATORS: 



Tally 
runout 



NOTES: 



C(Z), r C(MASK), & 

((C(Y-charn1)J_ 1 )j « (C(Y-charn2) ) j) 

If C(Z) 8 = 00. . .0, then 
00. ..0 -> C(Y3) n 
i-1 -> C(Y3)i 2f 35 
otherwise, continue scan of C(Y-charnl) 
If a masked character match was not found, then 
00. ..0 -> C(Y3) ,11 
N1 -> C(Y3)i2 >3 5 

None except au, qu, al, ql , xn for MF1 and REG 
None except du, au, qu, al, ql , xn for MF2 

(Indicators not listed are not affected) 

If the string length count exhausts, then ON; 
otherwise, OFF 

Both the string and the test character are treated as the 
data type given for the string, TA1. A data type given 
for the test character, TA2, is ignored. 

1 bits in C(MASK) specify those bits of each character 
that will not take part in the masked comparison. 

Instruction execution proceeds until a masked character 
match is found or the string length count is exhausted. 

Masking and comparison is done on full 9-bit fields. If 
the given data type is not 9-bit (TA1 i 0), then characters 
from C(Y-charnl) and C(Y-charn2) are high-order zero filled. 
All 9 bits of" C(MASK) are used. 

If MF1.RL = 1, then N1 does not contain the operand length; 
instead, it contains a register code for a register holding 
the operand length. 



If 
word 



MFk.ID = 1, then the kth word following the instruction 
d "does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

If MF2.ID = and MF2.REG = du , then the second word following 
the instruction word does not contain an operand descriptor 
for the test character; instead, it contains the test 
character as a direct upper operand in bits 0,8. 

Attempted execution with the xed instruction causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 
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scrar 



Scan with Mask in Reverse 



125 (1) 



FORMAT: 
SUMMARY: 



Same as Scan with Mask (scm) format (see Figure 4-15) 

For characters i = 1, 2, ..., N1 
For bits j = 0, 1, . . . , 8 



MODIFICATIONS: 



INDICATORS: 



C(Z)i = C(MASK) i & 

((CCY-charnDjJ^j) j (C(Y-charn2) ) j) 

If C(Z) 3 = 00 0, then 

00. ..0 -> C(Y3> 11 

i-1 -> C(Y3) 12 ,35 
otherwise, continue scan of C(Y-chanil) 
If a masked character match was not found, then 
00. ..0 -> C(Y3>o, 11 
N1 -> C(Y3) 12 ,35 



None except au, qu, al, ql , xn for MF1 and REG 
None except du, au, qu, al, qT, xri for MF2 

(Indicators not listed are not affected) 



Tally If the string 
runout otherwise, OFF 



length count exhausts, then ON; 



NOTES: 



Both the string and the test character are treated as the 
data type given for the string, TA1. A data type given 
for the test character, TA2, is ignored. 

1 bits in C(MASK) specify those bits of each character 
that will not take part in the masked comparison. 

Instruction execution proceeds until a masked character 
match is found or the string length count is exhausted. 

Masking and comparison is done on full 9-bit fields. If 
the given data type is not 9-bit (TA1 i 0), then characters 
from C(Y-charnl) and C(Y-charn2) are high-order zero filled. 
All 9 bits ofC(MASK) are used. 

If MF1.RL = 1, then N1 does not contain the operand length; 
instead, it contains a register code for a register holding 
the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

If MF2.ID = and MF2.REG = du, then the second word following 
the instruction word does not contain an operand descriptor 
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for the test character; instead, it contains the test 
character as a direct upper operand in bits 0,8. 

Attempted execution with the xed instruction causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd , or rpl instructions 
causes an illegal procedure fault. 



tct 



Test Character and Translate 



164 (1 



D 



FORMAT: 









1 
7 


1 2 


2 2 
1 2 


2 

1 


2 2 

4 7 


2 
9 


2 
.2- 


3 



3 

1 


3 3 
2 5 





000000000000000 


161 (1) 


I 


MF1 


Y-charn1 


CN1 


TA1 





10 1 

N1 


( 


Y-char92 


3 2 1 
00000000000 


A 








15 
REG 


Y3 


00000000000 


A 








REG 






18 










1 1 


I 




2 


4 



Figure 4-16. Test Character and Translate (tct) EIS Multiword 

Instruction Format 



MF1 

I 

Y-charn1 

CN1 

TA1 

N1 

Y-char92 

Y3 

A 

REG 



Modification field for operand descriptor 1 
Interrupt inhibit bit 

Address of string 

First character position of string 

Data type of string 

Length of string 

Address of character translation table 

Address of result word 

Indirect via pointer register flag for Y2 and Y3 

Register modifier for Y2 and Y3 



ALM Coding Format: 



tct 


(MF1) 


descna 


Y-charn1[(CN1)],N1 


arg 


Y-char92[,tag] 


arg 


Y3t,tag] 



4, 6, or 9 (TA1 =2, 1 , or 0) 
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SUMMARY: For i = 1, 2 N1 

m = CCY-charnDj.-! 

If C(Y-char92) m * 00... 0, then 

C(Y-char92) m -> C(Y3) 0> 8 

000 -> C(Y3) 9j11 

i-1 -> C(Y3) 12>3 5 
otherwise, continue scan of C(Y-char_n1) 
If a non-zero table entry was not found, then 
00. ..0 -> C(Y3) ,11 
N1 -> C(Y3) 12 ,35 

MODIFICATIONS: None except au, qu, al, ql , xn for MF1 and REG 

INDICATORS: (Indicators not listed are not affected) 

Tally If the string length count exhausts, then ON; 
runout otherwise, OFF 

NOTES: If the data type of the string to be scanned is not 9-bit 

(TA1 i 0), then characters from C(Y-charnl) are high-order 
zero filled in forming the table index, m. 

Instruction execution proceeds until a non-zero table entry 
is found or the string length count is exhausted. 

If MF1.RL = 1, then N1 does not contain the operand length; 
instead, it contains a register code for a register holding 
the operand length. 

If MF1.ID = 1, then the first word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

Attempted execution with the xed instruction causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 

The character number of Y-char92 must be zero, i.e. , Y-char92 
must start on a word boundary. 

If a non-zero table entry was not found, then 
00. ..0 -> C(Y3) ,ii 
N1 -> C(Y3)-i2,35 
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tctr 



Test Character and Translate in Reverse 



FORMAT: 



165 (1) 



Same as Test Character and Translate (tct) 
format (see Figure 1-16). 



SUMMARY: 



For i = 1, 2, .. ., N1 
m = C(Y-charn1 ) N i_ i 
If C(Y-char92) m * 00... 0, then 

C(Y-char92) m -> C(Y3) 0>8 

000 -> C(Y3) 9( - 11 

i_1 -> C(Y3) 12|35 
otherwise, continue scan of C(Y-charnl) 
If a non-zero table entry was not found, then 
00. ..0 -> C(Y3) 0>11 
N1 -> C(Y3>12,35 



MODIFICATIONS: 



None except au, qu, al, ql , xn for MF1 and REG 



INDICATORS: 



(Indicators not listed are not affected) 



Tally If the string length count exhausts, 
runout otherwise, OFF 



then 



ON: 



NOTES: 



If the data type of the string to be scanned is not 9-bit 
(TA1 t 0), then characters from C(Y-charnl) are high-order 
zero filled in forming the table index, m. 

Instruction execution proceeds until a non-zero table entry 
is found or the string length count is exhausted. 

If MF1.RL = 1, then N1 does not contain the operand length; 
instead, it contains a register code for a register holding 
the operand length. 

If MF1.ID = 1, then the first word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

Attempted execution with the xed instruction causes an illegal 
procedure fault. 

Attempted repetition with the rpt, rpd, or rpl instructions 
causes an illegal procedure fault. 
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EIS - Alphanumeric Move 



ralr 



Move Alphanumeric Left to Right 



FORMAT: 



100 (1) 








8 




9 


1 



1 
1 


1 
7 


1 2 
8 


2 2 
1 2 


2 
3 


2 
U 


2 
7 


2 

8 


2 
9 




3 

5 


FILL 


T 





MF2 


100 (1) 


I 


MF1 




9 1 1 
Y-charn1 




7 


CN1 


TA1 







10 1 

N1 




7 


Y-charn2 


CN2 


TA2 





N2 












18 


3 


2 


1 












12 



Figure 1-17. Move Alphanumeric Left to Right (mlr) EIS Multiword 

Instruction Format 



FILL 

T 

MF1 

MF2 

Y-charn1 

CM1 

TA1 

N1 

Y-charn2 

CN2 

TA2 

N2 



Fill character for string extension 

Truncation fault enable bit 

Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Address of sending string 

First character position of sending string 

Data type of sending string 

Length of sending string 

Address of receiving string 

First character position of receiving string 

Data type of receiving string 

Length of receiving string 



ALM Coding Format: 



mlr 

descna 

descna 



SUMMARY: 



(MF1 ) , (MF2) [ ,f ill(octalexpression) ][ .enablefault] 
Y-charn1[(CN1)],N1 n = 4, 6, or 9 (TA1 = 2, 1, or 0) 
Y-charn2[(CN2)],N2 n = U, 6, or 9 (TA2 =2, 1, or 0) 



For i = 1, 2, ..., minimum (N1.N2) 
C(Y-charn1) i _ 1 -> C(Y-charn2) i _ 1 
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If N1 < M2, then for i = M1+1, N1+2, . .., N2 
C(FILL) -> (XY-charn^)^., 

MODIFICATIONS: None except au, qu, al, ql, xn for MF1 and MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Truncation If NT > N2 then ON; otherwise OFF 



NOTES: 



If data types are dissimilar (TA1 t TA2) , each character 
is high-order truncated or zero filled, as appropriate, as 
it is moved. No character conversion takes place. 

If N1 > N2, then (N1-N2) trailing characters of 
C(Y-charnl) are not moved and the truncation indicator is 
set ON. 

If N1 < N2 and TA2. = 2 (4-bit data) or 1 (6-bit data), 
then FILL characters are high-order truncated as they are 
moved to C(Y-charn2). No character conversion takes 
place. 

If N1 < N2, C(FILL) = 1, TA1 = 1, and TA2 = 2, then 
C(Y-eharn1)jji_.| is examined for a GBCD overpunch sign. If 
a negative overpunch sign is found, then the minus sign 
character is placed in C(Y-charn2) N 2«i » otherwise, a plus 
sign character is placed in C(Y-charn"2) N 2_i • 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl) and C(Y-charn2) may be overlapping strings; no 
check is made. This feature is useful for replication of 
substrings within a larger string, but care must be 
exercised in the construction of the operand descriptors 
so that sending string, C(Y-charnl), data is not 
inadvertently destroyed. 

The user of string replication or overlaying is warned 
that the decimal unit addresses the main memory in 
unaligned (not on modulo 8 boundary) units of Y-block8 
words and that the overlayed string, C(Y-charn2) , is not 
returned to main memory until the unit of Y-block8 words 
is filled or the instruction completes. 

If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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FORMAT: 



Same as Move Alphanumeric Left to Right (mlr) 
format (see Figure 4-17). 



SUMMARY: 



For i = 1, 2, . .., minimum (N1,M2) 
CCY-charnDf,^ -> C(Y-charn2) f|2 _ i 

If N1 < M2, then for i = N1+1, N2+1 , , 
C(FILL) -> CtY-char^)^^ 



, N2 



MODIFICATIONS: 



None except au , qu, al, ql, xn for MF1 and MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Truncation If N1 > N2 then ON; otherwise OFF 



NOTES: 



If data types are dissimilar (TA1 i TA2), each character 
is high-order truncated or zero filled, - as appropriate, as 
it is moved. No character conversion takes place. 

If N1 > N2, then (N1-N2) leading characters of C(Y-charnl) 
are not moved and the truncation indicator is set ON. ~" 

If N1 < N2 and TA2 = 2 (4-bit data) or 1 (6-bit data), 
then FILL characters are high-order truncated as they are 
moved to C(Y-charn2). No character conversion takes 
place. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl) and C(Y-charn2) may be overlapping strings; no 
check is made. This feature is useful for replication of 
substrings within a larger string, but care must be 
exercised in the construction of the oper'and descriptors 
so that sending string, C(Y-charnl), data is not 
inadvertently destroyed. 

The user of string replication or overlaying is warned 
that the decimal unit addresses the main memory in 
unaligned (not on modulo 8 boundary) units of Y-block8 
words and that the overlayed string, C(Y-charn2), is not 
returned to main memory until the unit of Y-block8 words 
is filled or the instruction completes. 
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If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd , or rpl 
instructions causes an illegal procedure fault. 



mve 



Move Alphanumeric Edited 



020 (1) 



FORMAT: 




1 



2 



8 


1 

9 o 


1 
1 


1 
7 


1 2 
8 


2 2 
1 2 


2 
1 


2 

4 


2 2 2 
7 8 Q 




3 

5 





MF3 





MF2 


020 (1) 


I 


MF1 


2 


7 2 
Y-charn1 




7 


CN1 


TA1 







10 1 

N1 




7 


Y-char92 


CN2 





N2 


Y-charn3 


CN3 


TA3 





N3 



18 



2 1 



12 



Figure 4-18. Move Alphanumeric Edited (mve) EIS Multiword Instruction Format 



MF1 

MF2 

MF3 

I 

Y-charn1 

CN1 

TA1 

N1 

Y-char92 

CN2 

N2 

Y-charn3 

CN3 



Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Modification field for operand descriptor 3 

Interrupt inhibit bit 

Address of sending string 

First character position of sending string 

Data type of sending string 

Length of sending string 

Address of MOP control string 

First character position of MOP control string 

Length of MOP control string 

Address of receiving string 

First character position of receiving string 
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TA3 
N3 



Data type of receiving string 
Length of receiving string 



ALM Coding Format: 

mve 

descna 
desc9a 
descna 



SUMMARY: 



MODIFICATIONS: 
INDICATORS: 



(MF1),(MF2),(MF3) 
Y-charn1[(CN1)],N1 
Y-char92[(CN2)],N2 
Y-charn3[(CN3)],N3 



n = 4, 6, or 9 (TA1 =2, 1, or 0) 
n = 4, 6, or 9 (TA3 =2, 1 , or 0) 



C(Y-charnl) -> C(Y-charn3) under C(Y char92) MOP control 

See "Micro Operations for Edit Instructions" later in this 
section for details of editing under MOP control. 

None except au, qu, al , ql , xn for MF1, MF2, and MF3 
None affected 



NOTES: 



H Vtl* types are dissimilar (TA1 * TA3) , each character 
or CCY-Charnl) is high-order truncated or zero filled as 
appropriate, as it is moved. No character ' 
takes place. 



conversion 



If the data type of the receiving string is not 9-bit (TA3 
* 0), then insertion characters are high-order truncated 
as they are inserted. 

The maximum string length is 63. The count fields N1, N2 
and N3 are treated as modulo 64 numbers. * ' 

The instruction completes normally only if N3 is the first 
tally to exhaust: otherwise, an illegal procedure fault 
occurs. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnD- and C(Y-charn3) may be overlapping strings; no 
check is made. This feature is useful for replication of 
substrings within a larger string, but care must be 
exercised in the construction of the operand descriptors 
so that sending string, C(Y-charnl), data is not 
inadvertently destroyed. ~ 

The user of string replication or overlaying is warned 
that the decimal unit addresses the main memory in 
unaligned (not on modulo 8 boundary) units of Y-block8 
words and that the overlayed string, C(Y-charn3), is not 
returned to main memory until the unit of Y-block8 words 
is filled or the instruction completes. 
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Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



mvt 



Move Alphanumeric with Translation 



160 (1) 



FORMAT: 








8 




9 


1 
p 


1 

1 


1 
7 


1 2 
8 


2 2 
1 ?, 


2 

1 


2 
4 


2 
7 


2 

ft 


2 

9_ 


3 



3 
1 


3 3 
2 5 


FILL 


T 





MF2 


160 (1) 


I 


MF1 




9 1 1 
Y-charn1 




? 


CN1 


TA1 







10 1 

N1 


7 


Y-charn2 


CN2 


TA2 





N2 




Y-char93 




18 


3 2 1 
00000000 





A 








12 
REG 












1ft 










' 


11 


1 




2 


4 



Figure 4-1. Move Alphanumeric with Translation (mvt) EIS Multiword 

Instruction Format 



■FILL 

T 

MF1 

MF2 

Y-charn1 

CN1 

TA1 

N1 

Y-charn2 

CN2 

TA2 

N2 

Y-char93 

A 



Fill character for string extension 

Truncation fault enable bit 

Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Address of sending string 

First character position of sending string 

Data type of sending string 

Length of sending string 

Address of receiving string 

First character position of receiving string 

Data type of receiving string 

Length of receiving string 

Address of character translation table 

Indirect via pointer register flag for Y-char93 
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REG 



Register modifier for Y-char93 



ALM Coding Format: 



mvt ( M F1)»(MF2)[,fill(octalexpression)][,enablefault] 

descna Y-charn1 [(CN1 ) ] ,N1 n = 4, 6, or 9 (TA1 = 2, 1, or 0) 

descna Y-charn2[(CN2)] ,N2 n = 4, 6, or 9 (TA2 = 2, 1 or 0) 

ar S Y-char93C,tag] 



SUMMARY: 



MODIFICATIONS: 
INDICATORS: 



For i = 1, 2, ..., minimum (N1.N2) 

m = C(Y-charn1) i _ l 

C(Y-char93) m -> C(Y-charn2) i _ 1 
If N1 < N2, then for i = N1 + 1, N1+2, ..., N2 

m = C(FILL) 

C(Y-char93) m -> C(Y-charn2) i _ 1 

None except au, qu, al, ql, xn for MF1, MF2, and REG 
(Indicators not listed are not affected) 



Truncation If N1 > N2 then ON; otherwise OFF 



NOTES: 



If the data type of the receiving field is not 9-bit (TA2 
i 0), then characters from C(Y-char93) are high-order 
truncated, as appropriate, as they are moved. 

If the data type of the sending field is not 9-bit (TA1 i 
0), then characters from C(Y-charnl) are high-order zero 
filled when forming the table index. 

If "1 > N2, then (N1-N2) trailing characters of 
C(Y-charnl) are not moved and the truncation indicator is 
set ON. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl) and C(Y-charn2) may be overlapping strings; no 
check is made. This feature is useful for replication of 
substrings within a larger string, but care must be 
exercised in the construction of the operand descriptors 
so that sending string, C(Y-charnl), data is not 
inadvertently destroyed. 

The user of string replication or overlaying is warned 
that the decimal unit addresses the main memory in 
unaligned (not on modulo 8 boundary) units of Y-block8 
words and that the overlayed string, C(Y-charn2), is not 
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returned to main memory until the unit of Y-block8 words 
is filled or the instruction completes. 

If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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EIS - Numeric Compare 



cmpn 



Compare Numeric 



FORMAT: 








1 1 
1 



0000000000 



11 



Y-charnl 



Y-charn2 



MF2 



7S 



11 22222 2223 
-M 12^4 7 B q n 



303 (1) 



CN1 



CN2 



S1 



S2 



10 1 
SF1 



303 (1) 



MF1 



SF2 



N1 



N2 



3 1 2 - 6 S 
Figure 4-20. Compare Numeric (cmpn) EIS Multiword Instruction Format 



kev 



MF1 

MF2 

I 

Y-charnl 

CN1 

TN1 

S1 

SF1 

N1 

Y-charn2 

CN2 

TN2 

S2 

SF2 

N2 

ALM Coding Format; 



Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Interrupt inhibit bit 

Address of left-hand number 

First character position of left-hand number 

Data type of left-hand number 

Sign and decimal type of left-hand number 

Scaling factor of left-hand number 

Length of left-hand number 

Address of right-hand number 

First character position of right-hand number 

Data type of right-hand number 

Sign and decimal type of right-hand number 

Scaling factor of right-hand number 

Length of right-hand string 
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cmpn 

descn[fl,ls,ns,ts] 
descn [ f 1 , Is , ns , ts ] 



(MF1),(MF2) . 

Y-charn1[(CN1)],N1 ,SF1 n = 4 or 9 

Y-charn2[(CN2)],N2,SF2 n = 4 or 9 



SUMMARY: 



C(Y-charnl) 



C(Y-charn2) as numeric values 



MODIFICATIONS: 



None except au, qu, al , ql, xn for MF1 and MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y-charnl) = C(Y-charn2), then ON; otherwise OFF 
Negative If C(Y-charnl) > C(Y-charn2), then ON; otherwise OFF 
Carry If j C(Y-charn1 ) J > ! C(Y-charn2) ! , then OFF, otherwise ON 



NOTES: 



Comparison is made on 4-bit numeric values contained in 
each character of C(Y-charnk). If either given data type 
is 9-bit (TNk = 0), characters from C(Y-char9k) are 
high-order truncated to 4 bits before comparison. 

Sign characters are located according to information in 
CNk, Sk, and Nk and interpreted as 4-bit fields; 9-bit 
sign characters are high-order truncated before 
interpretation. The sign character 15g is interpreted as 
a minus sign; all other legal sign characters are 
interpreted as plus signs. 

The position of the decimal point in C(Y-charnk) is 
determined from information in CNk, Sk, SFk, and Nk. 

Comparison begins at the decimal position corresponding to 
the first digit of the operand with the larger number of 
integer digits and ends with the last digit of the operand 
with the larger number of fraction digits. 

Four-bit numeric zeros are used to represent digits to the 
left of the first given digit of the operand with the 
smaller number of integer digits. 

Four-bit numeric zeros are used to represent digits to the 
right of the last given digit of the operand with the 
smaller number of fraction digits. 

Instruction execution proceeds until an inequality is 
found or the larger string length count is exhausted. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an* operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 



Detection of a character outside the range [0,11]g in 
digit position or a character outside the range [12,17] 
in a sign position causes an illegal procedure fault. 
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Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd , or rpl 
instructions causes an illegal procedure fault. 
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mvn 



Move Numeric 



FORMAT: 



EIS - NUMERIC MOVE 



300 (1) 









1 



8 



Q 


1 



1 
1 




1 
7 


1 2 
8 


2 

1 


2 2 
2 T 


2 
4 


2 
7 


2 

8 


2 
9 


3 





3 

S 


p 


( 


5 


T 


R 


MF2 


300 (1) 


I 


MF1 


1 


1 1 
Y-charn1 




7 


CN1 


a 


S1 


10 1 
SF1 




N1 


7 


Y-charn2 


CN2 


b 


S2 


SF2 


N2 
















18 


3 


1 


2 








6 






6 



Figure 4-21. Move Numeric (mvn) EIS Multiword Instruction Format 



key 

P 

T 

R 

MF1 

MF2 

I 

Y-charn1 

CN1 
a TN1 

S1 

SF1 

N1 

Y-charn2 

CN2 
b TN2 

S2 

SF2 

N2 



4-bit data sign character control 

Truncation fault enable bit 

Rounding flag 

Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Interrupt inhibit bit 

Address of sending number 

First character position of sending number 

Data type of sending number 

Sign and decimal type of sending number 

Scaling factor of sending number 

Length of sending number 

Address of receiving number 

First character position of receiving number 

Data type of receiving number 

Sign and decimal type of receiving number 

Scaling factor of receiving number 

Length of receiving string 
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ALM Coding Format: 

mvn 

descn[fl,ls,ns,ts] 

descn[fl,ls,ns,ts] 



(MF1),(MF2)[,enablefault][, round] 
Y-charn1[(CN1)],N1,SF1 n = 4 or 9 
Y-charn2[(CN2)],N2,SF2 n" = 4 or 9 



SUMMARY 



C(Y-charnl) converted and/or rescaled -> C(Y-charn2) 



MODIFICATIONS: None except au, qu, al, ql, xn for MF1 and MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 
Negative 

Truncation 

Overflow 



Exponent 
overflow 

Exponent 
underflow 



If C(Y-charn2) = decimal 0, then ON; otherwise OFF 

If a minus sign character is moved to C(Y-charn2), then 
ON; otherwise OFF - 

If low-order digit truncation occurs without rounding, 
then ON; otherwise OFF 

If fixed-point integer overflow occurs, then ON: otherwise 
unchanged, (see NOTES) 

If exponent of floating-point result exceeds +127, then 
ON; otherwise unchanged. 

If exponent of floating-point result is less than -128 
then ON; otherwise unchanged. ~ ' 



NOTES: 



If data types are dissimilar (TN1 i TN2), each character 
is high-order truncated or filled, as appropriate, as it 
is moved. The fill data used is "0001 1"b for digit 
characters and "00010"b for sign characters. 



and P z 
C(Y-charnl) 



1, 
is 



If TN2 and S2 specify a 4-bit signed number 
then a legal plus sign character in 
converted to 13 g as it is moved. 

If N2 is not large enough to hold the integer part of 
C(Y-charnl) as rescaled by SF2, an overflow condition 
exists; the overflow indicator is set ON and an overflow 
fault occurs. This implies that an unsigned fixed-point 
receiving field has a minimum length of 1 character: a 
signed fixed-point field, 2 characters; and a 
floating-point field, 3 characters. 

If N2 is not large enough to hold all the given digits of 
C(Y-charnl) as rescaled by SF2 and R = 0, then a 
truncation condition exists; data movement stops when 
C(Y-charn2) is filled and the truncation indicator is set 
ON. If R = 1, then the last digit moved is rounded 
according to the absolute value of the remaining digits of 
C(Y-charnl) and the instruction completes normally. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 
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If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl) and C(Y-charn2) may be overlapping strings; no 
check is made. This feature is useful for replication of 
substrings within a larger string, but care must be 
exercised in the construction of the operand descriptors 
so that sending string, C(Y-charnl), data is not 
inadvertently destroyed. Difficulties may be encountered 
because of scaling factors and the special treatment of 
sign characters and floating-point exponents. 

The user of string replication or overlaying is warned 
that the decimal unit addresses the main memory in 
unaligned (not on modulo 8 boundary) units of Y-block8 
words and that the overlayed string, C(Y-charn2) , is not 
returned to main memory until the unit of Y-bIock8 words 
is filled or the instruction completes. 

If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 

Detection of a character outside the range [0,11] 8 in a 
digit position or a character outside the range [T2,17] 8 
in a sign position causes an illegal procedure fault. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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mvne 



Move Numeric Edited 



FORMAT: 



02U (1) 




1 



2 




9 


1 


1 
1 


1 
7 


1 2 
8 


2 

1 


2 
2 


2 
3 


2 
4 


2 

7 


2 

8 


2 
q 




3 





MF3 





MF2 


024 (1) 


I 




MF1 




2 


7 2 

Y-charn1 




7 


CN1 


a 


S1 





10 1 



N1 


7 


Y-char92 


CN2 


1 2 




6 

0000 


N2 


Y-charn3 


CN1 


TA3 





9 



N3 












18 


3 




2 


1 








6 




~r 



Figure 4-22. Move Numeric Edited (mvne) EIS Multiword Instruction Fo 



rmat 



key 



MF1 

MF2 

MF3 

I 

Y-charn1 

CN1 

TN1 

S1 

N1 

Y-char92 

CN2 

N2 

Y-charn3 

CN3 

TA3 

N3 

ALM Coding Format: 



Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Modification field for operand descriptor 3 

Interrupt inhibit bit 

Address of sending string 

First character position of sending string 

Data type of sending string 

Sign and decimal type of sending string 

Length of sending string 

Address of MOP control string 

First character position of MOP control string 

Length of MOP control string 

Address of receiving string 

First character position of receiving string 

Data type of receiving string 

Length of receiving string 
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mvne 

descn[fl,ls,ns,ts] 

desc9a 

descna 



(MF1),(MF2),(MF3) 
Y-charn1[(CN1)],N1 
Y-char92[(CN2)],N2 
Y-charn3C(CN3]),N3 



n : 1 or 9 

n = 1, 6, or 9 



SUMMARY: C(Y-charnl) -> C(Y-charn3) under C(Y_char92) MOP control 

See "Micro Operations for Edit Instructions" later in this 
section for details of editing under MOP control. 

MODIFICATIONS: None except au, qu, al , ql, xn for MF1, MF2, and MF3 

INDICATORS: None affected 



NOTES: 



If data types are dissimilar (TA1 t TA3) , each character 
of C(Y-charnl) is high-order truncated or zero filled, as 
appropriate, as it is moved. No character conversion 
takes place. 

If the data type of the receiving string is not 9-bit (TA3 
i 0) , then insertion characters are high-order truncated 
as they are inserted. 

The maximum string length is 63. The count fields N1, N2, 
and N3 are treated as modulo 64 numbers. 

The instruction completes normally only if N3 is the first 
tally to exhaust: otherwise, an illegal procedure fault 
occurs. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl) and C(Y-charn3) may be overlapping strings; no 
check is made. This feature is useful for replication of 
substrings within a larger string, but care must be 
exercised in the construction of the operand descriptors 
so that sending string, C(Y-charnl), data is not 
inadvertently destroyed. 

The user of string replication or overlaying is warned 
that the decimal unit addresses the main memory in 
unaligned (not on modulo 8 boundary) units of Y-block8 
words and that the overlayed string, C(Y-charn3), is not 
returned to main memory until the unit of Y-bT.ock8 words 
is filled or the instruction completes. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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EIS - Bit String Combine 



csl 



Combine Bit Strings Left 



FORMAT: 



060 (1) 









1 



4 




5, 9 



9 


1 



1 
1 


1 
7 


1 1 
8 q 


2 2 
7 


2 
4 


2 

7 


2 


2 
q 




3 


F 








BOLR 


T 





MF2 


060 (1) 


i 




MF1 


— 2- 


i 


<* 4 11 
Y-bit1 




7 


C1 


B1 


10 1 


N1 




7 




Y-bi 


t2 






C2 


B2 


M2 










18 


2 


4 












12 



Figure 4-23. Combine Bit Strings Left (csl) EIS Multiword Instruction 



Format 



F 

BOLR 

T 

MF1 

MF2 

I 

Y-bitl 

C1 

B1 

N1 

Y-bit2 

C2 

B2 

N2 



Fill bit for string extension 

Boolean result control field 

Truncation fault enable bit 

Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Interrupt inhibit bit 

Address of sending string 

First character position of sending string 

First bit position of sending string 

Length of sending string 

Address of receiving string 

First character position of receiving string 

First bit position of receiving string 

Length of receiving string 



ALM Coding Format: 

csl (MF1),(MF2)[ f enablefault][,bool(octalexpression)][,fill(o:i)] 
descb Y-bitU(BITN01)3,N1 |UJ 

descb Y-bit2[(BITN02)],N2 
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SUMMARY: 



For i = bits 1, 2, ..., minimum (N1.N2) 

m = CCY-bitD^-, !! C(Y-bit2) i _ 1 (a 2-bit number) 

C(BOLR) m -> C(Y-bit2) i _ 1 
If N1 < N2, then for i = N1 + 1, N1+2 N2 

m = C(F) i! C(Y-bit2) i _ 1 (a 2-bit number) 

C(BOLR) m -> C(Y-bit2) i _ 1 



MODIFICATIONS: 



None except au, qu, al , ql , xn for MF1 and MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y-bit2) = 00... 0, then ON; otherwise OFF 
Truncation If N1 > N2, then ON; otherwise OFF 

NOTES: If N1 > N2, the low order (N1-N2) bits of C(Y-bit1) are 

not processed and the truncation indicator is set ON. 

The bit pattern in C(BOLR) defines the Boolean operation 
to be performed. Any of the sixteen possible Boolean 
operations may be used. Some common Boolean operations 
and their BOLR fields are shown below. 



Operation 


C(BOLR) 


MOVE 


0011 


AND 


0001 


OR 


0111 


NAND 


1110 


EXCLUSIVE OR 


0110 


Clear 


0000 


Invert 


1100 



If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-bit1) and C(Y-bit2) may be overlapping strings; no 
check is made.. -This feature is useful for replication of 
substrings within a larger string, but care must be 
exercised in the construction of the operand descriptors 
so that sending string, C(Y-bitl), data is not 
inadvertently destroyed. 
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The user of string replication or overlaying is warned 
that the decimal unit addresses the main memory in 
unaligned (not on modulo 8 boundary) units of Y-block8 
words and that the overlayed string, C(Y-b.it2), is not 
returned to main memory until the unit of Y-block8 words 
is filled or the instruction completes. 

If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 



csr 



Combine Bit Strings Right 



061 (1) 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 



Same as Combine Bit Strings Left (csl) (see Figure 4-23) 

For i = bits 1, 2, ..., minimum (N1.N2) 

m = C(T-bit1) M1 . l II C(Y-bit2) M2 _i (a 2 " bit number) 

C(BOLR) m -> C(Y-bit2) N2 _ i 
If N1 < N2, then for i = N1+1, N1+2, ..., N2 

m = C(F) Ji C(Y-bit2) N2 . i (a 2-bit number) 

C(B0LR) m -> C(Y-bit2) N2 _ i 

None except au, qu, al, ql, xn for MF1 and MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y-bit2) = 00... 0, then ON; otherwise OFF 
Truncation If N1 > N2, then ON; otherwise OFF 



NOTES: 



If N1 > N2, the high order (N1-N2) bits of C(Y-bit1) are 
not processed and the truncation indicator is set ON. 

The bit pattern in C(BOLR) defines the Boolean operation 
to be performed. Any of the sixteen possible Boolean 
operations may be used. See NOTES under the Combine Bit 
Strings Left (csl) instruction for examples of BOLR. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 
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If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-bit1) and C(Y-bit2) may be overlapping strings; no 
check is made. This feature is useful for replication of 
substrings within a larger string, but care must be 
exercised in the construction of the operand descriptors 
so that sending string, C(Y-bit1), data is not 
inadvertently destroyed. 

The user of string replication or overlaying is warned 
that the decimal unit addresses the main memory in 
unaligned (not on modulo 8 boundary) units of Y-block8 
words and that the overlayed string, C(Y-bit2), is not 
returned to main memory until the unit of Y-block8 words 
is filled or the instruction completes. 

If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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EIS - Bit String Compare 



cmpb 



Compare Bit Strings 



FORMAT: 


1 



11 

8 9 1 



00000000 



8 1 1 
Y-bit1 



Y-bit2 



MF2 



066 (1) 



C1 



C2 



B1 



B2 



1112 2 2 2 2 2 
7,8 2 L- !i ZJL3 



10 1 



N1 



N2 



066 (1) 



MF1 



18 2 4 : — 

Figure 4-24. Compare Bit Strings (cmpb) EIS Multiword Instruction Format 



F 

T 

MF1 

MF2 

I 

Y-bit1 

C1 

B1 

N1 

Y-bit2 

C2 

B2 

N2 

ALM Coding Format: 



Fill bit for string extension 

Truncation fault enable bit 

Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Interrupt inhibit bit 

Address of left-hand string 

First character position of left-hand string 

First bit position of left-hand string 

Length of left-hand string 

Address of right-hand string 

First character position of right-hand string 

First bit position of right-hand string 

Length of right-hand string 



cmpb (MF1) ,(MF2)[ f enablefault][, fill (011)] 
descb Y-bit1[(BITN01)],N1 
descb Y-bit2[(BITN02)],N2 



SUMMARY: 



For i = 1, 2, ..., minimum (N1,N2) 
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ca-bitl)^., :: C(Y-bit2) i _ 1 
If M1 < N2, then for i = N1+1, N1+2, . 

C(FILL) :: C(Y-bit2) jL _ 1 
If N1 > N2, then for i = N2+1 , N2+2, . 

ca-bitl)^., :: C(FILL) 



, N2 



... N1 



MODIFICATIONS: 
INDICATORS: 



Hone except au, qu, al, ql, xn for MF1 and MF2 



(Indicators not listed are not affected) 



Zero 



carry 



If C(Y-bit1) ± = C(Y-bit2) 1 for all i, then ON; 
otherwise, OFF 

If CU-bitDi < C(Y-bit2)i for any i, then OFF; 
otherwise ON 



NOTES: 



Instruction execution proceeds until an inequality is 
found or the larger string length count is exhausted. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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EIS - Bit String Set Indicators 



sztl 



Set Zero and Truncation Indicators with Bit Strings Left 



FORMAT: 
SUMMARY: 



MODIFICATIONS: 



064 (1) 



Same as Combine Bit Strings Left (csl) (see Figure 4-23) 

For i = bits 1, 2, ..., minimum (N1,N2) 

m = C(Y-bit1) i _ 1 !! C(Y-bit2) i _ 1 (a 2-bit number) 

If C(B0LR) m i 0, then terminate 
If N1 < N2, then for i = N1 + 1, N1+2, ..., N2 

m = C(F) II C(Y-bit2) i _ 1 (a 2-bit number) 

If C(BOLR) m i 0, then terminate 

None except au, qu , al, ql, xn for MF1 and MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(BOLR) m = for all i, then ON; otherwise OFF 
Truncation If N1 > N2, then ON; otherwise OFF 



NOTES: 



If N1 > N2, the low order (N1-N2) bits of C(Y-bit1) are 
not processed and the truncation indicator is set ON. 

The execution of this instruction is identical to the 
Combine Bit Strings Left (csl) instruction except that 
C(BOLR) m is not placed into C(Y-bit2) i _ 1 . 

The bit pattern in C(BOLR) defines the Boolean operation 
to be performed. Any of the sixteen possible Boolean 
operations may be used. See NOTES under the Combine Bit 
Strings Left (csl) instruction for examples of BOLR. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the k'th word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the. operand descriptor. 



If 
ex 
fault occurs 



T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 



Attempted execution with the xed instruction causes an 
illegal procedure fault. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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sztr 



Set Zero and Truncation Indicators with Bit Strings Right 



065 (1) 



FORMAT: 



Same as Combine Bit Strings Left (csl) (see Figure 4-23) 



SUMMARY: 



For i = bits 1, 2, ..., minimum (N1,N2) 

m = C(Y-bit1) N1 _ l !! C(Y-bit2) N2 _ i (a 2-bit number) 

If C(B0LR) m i 0, then terminate 
If N1 < N2, then for i = N1 + 1 , N1+2, ..., N2 

m = C(F) !! C(Y-bit2) N2 _ i (a 2-bit number) 

If C(B0LR) m i 0, then terminate 



MODIFICATIONS: None except au, qu, al, ql, xn for MF1 and MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(B0LR)m = for all i, then ON; otherwise OFF 
Truncation If N1 > N2, then ON; otherwise OFF 



NOTES: 



If N1 > N2, the low order (N1-N2) bits of C(Y-bit1) are 
not processed and the truncation indicator is set ON. 

The execution of this instruction is identical to the 
Combine Bit Strings Right (csr) instruction except that 
C(BOLR) m is not placed into C(Y-bit2) N2 _i. 

The bit pattern in C(BOLR) defines the Boolean operation 
to be performed. Any of the sixteen possible Boolean 
operations may be used. See NOTES under the Combine Bit 
Strings Left (csl) instruction for examples of BOLR. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk. ID = 1 , then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 



Attempted repetition with the rpt, rpd, 
instructions causes an illegal procedure fault. 



or 



rpl 
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EIS - Data Conversion 



btd 



Binary to Decimal Convert 



301 (1) 



FORMAT: 








1 


1 




1 
1 




1 
7 


1 2 
8 


2 

1 


2 2 
2 3 


2 
4 


2 
7 


2 
8 


2 
9 
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? 
5 
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301 (1) 


I 


MF1 


1 


10 
Y-char91 




7 


CN1 





10 1 





N1 
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6 



Figure 4-25. Binary to Decimal Convert (BTD) EIS Multiword Instruction Format 



key 



P 

MF1 

MF2 

I 

Y-char91 

CN1 

N1 

Y-charn2 

CN2 

TN2 

S2 

N2 



4-bit data sign character control 

Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Interrupt inhibit bit 

Address of binary number 

First byte position of binary number 

Length of binary number in 9-bit bytes 

Address of decimal number 

First character position of decimal number 

Data type of decimal number 

Sign and decimal type of decimal number 

Length of decimal number 



ALM Coding Format: 

btd 

desc9a 

descn[ls,ns,ts] 



(MF1),(MF2) 

Y-char91[(CN1)],N1 

Y-charn2[(CN2)],N2 



4 or 9 



SUMMARY: 



C(Y-char91) converted to decimal -> C(Y-charn2) 



2/82 
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MODIFICATIONS: 



None except au, qu, al, ql , xn for MF1 ad MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y-charn2) = decimal 0, then ON: otherwise OFF 

Negative If a minus sign character is moved to C(Y-charn2) , then 
ON; otherwise OFF 

Overflow If fixed-point integer overflow occurs, then OH; otherwise 
unchanged (see NOTES) 



NOTES: 



C(Y-char91) contains a twos complement binary integer 
aligned on 9-bit character boundaries with length < N1 
<= 8. 

If TN2 and S2 specify a 4-bit signed number and P = 1, 
then if C(Y-char9D is positive (bit of C(Y-char9D = 
0), then the 13g plus sign character is moved to 
C(Y-charn2) as appropriate. 

The scaling factor of C(Y-charn2) , SF2, must be 0. 

If N2 is not large enough to hold the digits generated by 
conversion of C(Y-char91) an overflow condition exists; 
the overflow indicator is set ON and an overflow fault 
occurs. This implies that an unsigned fixed-point 
receiving field has a minimum length of 1 character and a 
signed fixed-point field, 2 characters. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-char91) and C(Y-charn2) may be overlapping strings; no 
check is made. 

Attempted conversion to a floating-point number (S2 = 0) 
or attempted use of a scaling factor (SF2 i- 0) causes an 
illegal procedure fault. 

If N1 = or N1 > 8 an illegal procedure fault occurs. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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dtb 



Decimal to Binary Convert 



305 (1) 



FORMAT: 
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1 




1 
7 


1 2 
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2 2 
Z 3 
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MF2 


305 (1) 


I 


MF1 




11 

Y-charn1 




7 


CN1 


a 


S1 


10 1 





N1 


7 


Y-char92 


CN2 


1 2 6 
000000000 


N2 
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3 










9 






X 



Figure 4-26. Decimal to Binary Convert (dtb) EIS Multiword Instruction Format 



key 



MF1 

MF2 

I 

Y-charn1 

CN1 

TN1 

S1 

N1 

Y-charn2 

CN2 

N2 



Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Interrupt inhibit bit 

Address of decimal number 

First character position of decimal number 

Data type of decimal number 

Sign and decimal type of decimal number 

Length of decimal number 

Address of binary number 

First byte position of binary number 

Length of binary number in 9-bit bytes 



ALM Coding Format: 

dtb 

descn[ls,ns,ts] 

desc9a 



(MF1),(MF2) 

Y-charn1[(CN1)],N1 

Y-char92[(CN2)],N2 



n = 4 or 9 



SUMMARY: 



C(Y-charnl) converted to binary -> C(Y-char92) 



MODIFICATIONS: None except au, qu, al, ql, xn for MF1 ad MF2 



INDICATORS: 



(Indicators not listed are not affected) 



2/82 
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NOTES: 



EIS - DATA CONVERSION 



Zero If C(Y-char92) = 0, then ON: otherwise OFF 

Negative If a minus sign character is found in C(Y-charnl), then 
ON; otherwise OFF — 

Overflow If fixed-point integer overflow occurs, then ON; otherwise 
unchanged (see NOTES) 

C(Y-char92) will contain a twos complement binary integer 
aligned on 9-bit byte boundaries with length < N2 <= 8. 

The scaling factor of C(Y-charnl), SF1 , must be 0. 

If N2 is not large enough to hold the converted value of 
C(Y-charnl) an overflow condition exists; the overflow 
indicator is set ON and an overflow fault occurs. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl) and C(Y-char92) may be overlapping strings; no 
check is made. 

Attempted conversion of a floating-point number (S1 = 0) 
or attempted use of a scaling factor (SF1 i. 0) causes an 
illegal procedure fault. 

If N2 = or N2 > 8 an illegal procedure fault occurs. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



4-229 AL39 



EIS - DECIMAL ADDITION 



EIS - Decimal Additi 



on 



ad2d 



Add Using Two Decimal Operands 



FORMAT: 



202 (1) 



Figure 4-27. Add Using Two Decimal Operands (ad2d) EIS Multiword 

Instruction Format 








1 




- • § 




9 


1 
p 


1 
1 




1 
7 


1 2 
8 


2 
1 


2 2 
2 3 


2 
4 


2 
7 


2 

a 


2 
9 


3 
n 




3 


p 








T 


R 


MF2 


202 (1) 


i 


MF1 


1 


1 1 

Y-charn1 




7 


CN1 


a 


S1 


10 1 
SF1 




M1 


7 


Y-charn2 


CN2 


b 


S2 


SF2 


N2 
















18 


3 


1 


2 








6 






6 



key 



P 

T 

R 

MF1 

MF2 

I 

Y-charn1 

CN1 



a TN1 



S1 



SF1 

N1 

Y-charn2 



4-bit data sign character control 

Truncation fault enable bit 

Rounding flag 

Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Interrupt inhibit bit 

Address of augend (ad2d), minuend (sb2d), multiplicand 
(mp2d), or divisor (dv2d) 

First character position of augend (ad2d), minuend (sb2d), 
multiplicand (mp2d), or divisor (dv2d) 

Data type of augend (ad2d), minuend (sb2d), multiplicand 
(mp2d), or divisor (dv2d) 

Sign and decimal type of augend (ad2d), minuend (sb2d), 
multiplicand (mp2d), or divisor (dv2d) 

Scaling factor of augend (ad2d), minuend (sb2d), 
multiplicand (mp2d), or divisor (dv2d) 

Length of augend (ad2d), minuend (sb2d), multiplicand 
(mp2d), or divisor (dv2d) 

Address of addend and sum (ad2d), subtrahend and 
difference (sb2d), multiplier and product (mp2d), or 
dividend and quotient (dv2d) 
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CN2 First character position of addend and sum (ad2d), 

subtrahend and difference (sb2d), multiplier and product 
(mp2d), or dividend and quotient (dv2d) 

b TN2 Data type of addend and sum (ad2d), subtrahend and 

difference (sb2d), multiplier and product (mp2d), or 
dividend and quotient (dv2d) 

S2 Sign and decimal type of addend and sum (ad2d), subtrahend 

and difference (sb2d), multiplier and product (mp2d) , or 
dividend and quotient (dv2d) 

SF2 Scaling factor of addend and sum (ad2d), subtrahend and 

difference (sb2d), multiplier and product (mp2d), or 
dividend and quotient (dv2d) 



N2 



Length of addend and sum (ad2d), subtrahend and difference 
(sb2d), multiplier and product (mp2d), or dividend and 
quotient (dv2d) 



ALM Coding Format: 

ad 2 d (MF1 ) , (MF2) [ .enablef ault] [ .round] 

descn[fl,ls,ns,ts] Y-charn1[ (CN1) ] ,N1 ,SF1 n = 4 or 9 
descn[fl,ls,ns,ts] Y-charn2[ (CN2) ] ,N2, SF2 n = 4 or 9 

SUMMARY: C(Y-charnl) + C(Y-charn2) -> C(Y-charn2) 

MODIFICATIONS: None except au, qu, al, ql, xn for MF1 and MF2 

INDICATORS: (Indicators not listed are not affected) 

Zero If C(Y-charn2) = decimal 0, then ON; otherwise OFF 

Negative If C(Y-charn2) is negative, then ON; otherwise OFF 

Truncation If the truncation condition exists without rounding, then 
ON; otherwise OFF see NOTES) 

Overflow If the overflow condition exists, then ON; otherwise 
unchanged (see NOTES) 

Exponent If exponent of floating-point result exceeds 127 then 
overflow ON; otherwise unchanged. 

Exponent If exponent of floating-point result is less than -128 
underflow then ON; otherwise unchanged 



NOTES: If TN2 and S2 specify a 4-bit signed number and P = 1 

then the 13q plus sign character is placed appropriatel 
if the result of the operation is positive. 



If N2 is not large enough to hold the integer part of the 
result as scaled by SF2, an overflow condition exists; 
the overflow indicator is set ON and an overflow fault 
occurs. This implies that an unsigned fixed-point 
receiving field has a minimum length of 1 character; a 
signed fixed-point field, 2 characters; and a 
floating-point field, 3 characters. 
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If N2 is not large enough to hold all the digits of the 
result as scaled by SF2 and R = 0, then a truncation 
condition exists; data movement stops when. C(Y-charn2) is 
filled and the truncation indicator is set ON. If f = 1 
then the last digit moved is rounded according to the 
absolute value of the remaining digits of the result and 
the instruction completes normally. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead it 
contains an indirect pointer to the operand descriptor! 

C(Y-charnl) and C(Y-charn2) may be overlapping strings: no 
check is made. 

If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 



Detection of a character outside the range [0,11] ft in a 
digit position or a character outside the range [T2,17]o 
in a sign position causes an illegal procedure fault. 



Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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ad3d 



Add Using Three Decimal Operands 



222 (1) 



FORMAT: 
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Figure 4-28. Add Using Three Decimal Operands (ad3d) EIS Multiword 

Instruction Format 



key_ 



P 

T 

R 

MF1 

MF2 

MF3 

I 

Y-charn1 

CN1 



a TN1 
S1 
SF1 
N1 



Y-charn2 



4-bit data sign character control 

Truncation fault enable bit 

Rounding flag 

Modification field for operand descriptor 1 

Modification field for operand descriptor 2 

Modification field for operand descriptor 3 

Interrupt inhibit bit 

Address of augend (ad3d), minuend (sb3d), multiplicand 
(mp3d), or divisor (dv3d) 

First character position of augend (ad3d), minuend (sb3d) , 
multiplicand (mp3d), or divisor (dv3d) 

Data type of augend (ad3d), minuend (sb3d), multiplicand 
(mp3d), or divisor (dv3d) 

Sign and decimal type of augend (ad3d), minuend (sb3d), 
multiplicand (mp3d), or divisor (dv3d) 

Scaling factor of augend (ad3d), minuend (sb3d) , 
multiplicand (mp3d), or divisor (dv3d) 

Length of augend (ad3d), minuend (sb3d), multiplicand 
(rap3d), or divisor (dv3d) 

Address of addend (ad3d), subtrahend (sb3d), multiplier 
(mp3d), or dividend (dv3d) 
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CN2 



SF2 
N2 



First character position of addend (ad3d), subtrahend 
(sb3d), multiplier (mp3d), or dividend (dv3d) 

b TN2 ° at t type of addend (ad3d), subtrahend (sb3d), multiplier 

(mp3d), or dividend (dv3d) 

S2 Si «n and decimal type of addend (ad3d), subtrahend (sb3d) 

multiplier (mp3d), or dividend (dv3d) 

Scaling factor of addend (ad3d), subtrahend (sb3d), 
multiplier (mp3d), or dividend (dv3d) 

Length of addend (ad3d), subtrahend Csb3d), multiplier 
(mp3d), or dividend (dv3d) 

Y-charn3 Address of sum (ad3d), difference (sb3d), product (mp3d) 
or quotient (dv3d) 

CN 3 First character position of sura (ad3d), difference (sb3d) 

product (mp3d), or quotient (dv3d) 

c ™ 3 ° afca type of sum (ad3d), difference (sb3d), product 

(mp3d), or quotient (dv3d) 

S3 Si 8n and decimal type of sum (ad3d) f difference (sb3d), 

product (mp3d), or quotient (dv3d) 

SF3 Scaling factor of sum (ad3d) , difference (sb3d), product 

(mp3d) f or quotient (dv3d) 

Length of sum (ad3d), difference (sb3d), product (mp3d), 
or quotient (dv3d) 



N3 



ALM Coding Format: 

ad 3<* r _ (MFD, (MF2),(MF3)C,enablefault][, round] 

descn[fl,ls,ns,ts] Y-charn1 [ (CND ] ,N1 ,SF1 n = 4 or 9 

descn[fl,ls,ns,ts] Y-charn2[ (CN2) ] ,N2,SF2 rf = 4 or 9 

descn[fl,ls,ns,ts] Y-charn3[(CN3) ] ,N3,SF3 n = 4 or 9 

SUMMARY: ' C(Y-charnD + C(Y-charn2) -> C(Y-charn3) 

MODIFICATIONS: None except au, qu , al , ql, xn for MF1 and MF2 

INDICATORS: (Indicators not listed are not affected) 

Zero If C(Y-charn3) = decimal 0, then ON; otherwise OFF 

Negative If C(Y-charn3) is negative, then ON; otherwise OFF 

Truncation If the truncation condition exists without rounding, then 
ON; otherwise OFF (see NOTES) 

Overflow If the overflow condition exists, then ON; otherwise 
unchanged (see NOTES) 

Exponent If exponent of floating-point result exceeds 127 then 
overflow ON; otherwise unchanged. 
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NOTES: 
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Exponent If exponent of floating-point result is less than -128 
underflow then ON; otherwise unchanged 

If TN3 and S3 specify a 4-bit signed number and P = 1 , 
then the 13g plus sign character is placed appropriately 
if the result of the operation is positive. 

If N3 is not large enough to hold the integer part of the 
result as scaled by SF3, an overflow condition exists; 
the overflow indicator is set ON and an overflow fault 
occurs. This implies that an unsigned fixed-point 
receiving field has a minimum length of 1 character; a 
signed fixed-point field, 2 characters; and a 
floating-point field, 3 characters. 

If M3 is not large enough to hold all the digits of the 
result as scaled by SF3 and R = 0, then a truncation 
condition exists; data movement stops when C(Y-charn3) is 
filled and the truncation indicator is set ON. If R = 1, 
then the last digit moved is rounded according to the 
absolute value of the remaining digits of the result and 
the instruction completes normally. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl), C(Y-charn2) , and C(Y-charn3) may be 
overlapping strings; no check is made. 

If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 

Detection of a character outside the range [0,11]o in a 
digit position or a character outside the range [T2,17]o 
in a sign position causes an illegal procedure fault. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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EIS - Decimal Subtraction 



sb2d 



Subtract Using Two Decimal Operands 



FORMAT: 



203 (1) 



Same as Add Using Two Decimal Operands (ad2d) 
(see Figure 4-27). 



SUMMARY: 

MODIFICATIONS: 

INDICATORS: 



C(Y-eharnl) - C(Y-charn2) -> C(Y-charn2) 

None except au, qu, al, ql f xn for MF1 and MF2 

(Indicators not listed are not affected) 



Zero 

Negative 

Truncation 

Overflow 



Exponent 
overflow 

Exponent 
underflow 



If C(Y-charn2) = decimal 0, then ON; otherwise OFF 

If C(Y-charn2) is negative, then ON; otherwise OFF 

If the truncation condition exists without rounding, then 
ON; otherwise OFF (see NOTES) 

If the overflow condition exists, then ON; otherwise 
unchanged (see NOTES) lse 

If exponent of floating-point result exceeds 127 then 
ON; otherwise unchanged. 

If exponent of floating-point result is less than -128 
then ON; otherwise unchanged 



NOTES: 



If TN2 and S2 specify a 4-bit signed number and P = 1 
then the 13q Plus sign character is placed appropriately 
if the result of the operation is positive. 

If N2 is not large enough to hold the integer part of the 
result as scaled by SF2, an overflow condition exists- 
the overflow indicator is set ON and an overflow fault 
occurs. This implies that an unsigned fixed-point 
receiving field has a minimum length of 1 character- a 
signed fixed-point field, 2 characters: and' a 
floating-point field, 3 characters. 

If N2 is not large enough to hold all the digits of the 
result as scaled by SF2 and R = 0, then a truncation 
condition exists; data movement stops when C(Y-charn2) is 
filled and the truncation indicator is set ON. If R~ = 1 
then the last digit moved is rounded according to th 
absolute value of the remaining digits of the result an 
the instruction completes normally. 



1, 

e 

nd 



If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 
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If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl) and C(Y-charn2) may be overlapping strings: no 
check is made. 

If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 

Detection of a character outside the range [0,11]o in a 
digit position or a character outside the range [ f 2 , 1 7 ] ft 
in a sign position causes an illegal procedure fault. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd , or rpl 
instructions causes an illegal procedure fault. 



sb3d 



Subtract Using Three Decimal Operands 



223 (D 



FORMAT: 



Same as Add Using Three Decimal Operands (ad3d) 
(see Figure 4-28) . 



SUMMARY: 



C(Y-charnl) - C(Y-charn2) -> C(Y-charn3) 



MODIFICATIONS: None except au, qu, al, ql, xn for MF1 and MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Zero If C(Y-charn3) = decimal 0, then ON; otherwise OFF 

Negative If C(Y-charn3) is negative, then ON; otherwise OFF 

Truncation If the truncation condition exists without rounding, then 
ON; otherwise OFF (see NOTES) 

Overflow If the overflow condition exists, then ON; otherwise 
unchanged (see NOTES) 

Exponent If exponent of floating-point result exceeds 127 then 
overflow ON; otherwise unchanged. 

Exponent If exponent of floating-point result is less than -128 
underflow then ON; otherwise unchanged 



NOTES: 



If TN3 and S3 specify a 4-bit signed number and P = 1, 
then the 13c plus sign character is placed appropriately 
if the result of the operation is positive. 

If N3 is not large enough to hold the integer part of the 
result as scaled by SF3, an overflow condition exists; 
the overflow indicator is set ON and an overflow fault 
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™< l* X L t mplXSS tnat an ""signed fixed-point 
^noH ing pf le l d h - 3S . a minimum ^ngth of 1 character; a 
signed fixed-point field, 2 characters: and a 
floating-point field, 3 characters. 

If N3 is not large enough to hold all the didits of th# 

£Eft" SC % led , by SF3 and R = °» then a 8 truncation 
?!??i5 -n/fi St t ; d3t f ™ ovement st °Ps when C(Y-charn 3 ) is 
filled and the truncation indicator is set ON. If R - i 
then the last digit moved is rounded according to "the 
absolute value of the remaining digits of the rfsult an3 
the instruction completes normally. 

?L«rS' RL - \ 1 J tf ?! n N ^ does not contain the operand 
length; instead, it contains a register code for » 
register holding the operand length. egl " er code for a 

iL? F ^ ID = 1» the . n - the ^ th word Allowing the instruction 
^f, d "°< ° ontain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl), C(Y-charn2), and C(Y-charn3) may be 
overlapping strings; no check is made. ~ 

If T = 1 and the truncation indicator is set ON bv 
execution of the instruction, then a truncation (overflow) 
iauit occurs. 

Detection of a character outside the range [0,11],, in a 
digit position or a character outside the range [ f 2 17] Q 
in a sign position causes an illegal procedure fault.' 8 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rol 
instructions causes an illegal procedure fault. 
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EIS - Decimal Multiplication 



mp2d 



Multiply Using Two Decimal Operands 



206 (1) 



FORMAT: 



Same as Add Using Two Decimal Operands (ad2d) 
(see Figure 4-27). 



SUMMARY: 



C(Y-charnl) X C(Y-charn2) -> C(Y-charn2) 



MODIFICATIONS: None except au, qu, al , ql , xn for MF1 and MF2 



INDICATORS: 



(Indicators not listed are not affected) 



Zero 

Negative 

Truncation 

Overflow 



Exponent 
overflow 

Exponent 
underflow 



If C(Y-charn2) = decimal 0, then ON; otherwise OFF 

If C(Y-charn2) is negative, then ON; otherwise OFF 

If the truncation condition exists without rounding, then 
ON; otherwise OFF (see NOTES) 

If the overflow condition exists, then ON; otherwise 
unchanged (see NOTES) 

If exponent of floating-point result exceeds 127 then 
ON; otherwise unchanged. 

If exponent of floating-point result is less than -128 
then ON; otherwise unchanged 



NOTES: 



If TN2 and S2 specify a 4-bit signed number and P = 1 , 
then the 13g plus sign character is placed appropriately 
if the result of the operation is positive. 

If N2 is not large enough to hold the integer part of the 
result as scaled by SF2, an overflow condition exists; 
the overflow indicator is set ON and an overflow fault 
occurs. This implies that an unsigned fixed-point 
receiving field has a minimum length of 1 character; a 
signed fixed-point field, 2 characters; and a 
floating-point field, 3 characters. 

If N2 is not large enough to hold all the digits of the 
result as scaled by SF2 and R = 0, then a truncation 
condition exists; data movement stops when C(Y-charn2) is 
filled and the truncation indicator is set ON. If R = 1, 
then the last digit moved is rounded according to the 
absolute value of the remaining digits of the result and 
the instruction completes normally. 

If MFk.RL . s 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 
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5Lh 5 D = 1' the " - the * th word following the instruction 
^n?»?- eS no * c . ont « in an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor! 

Shlck h is-Md" d C(Y - Char ^ 2) ma * be overlapping strings; no 

If T 4./ 1 <. a I!!? fc . he tr "ncation indicator is set ON bv 
execution of the instruction, then a truncation (overflow? 
fault occurs. 

Detection of a character outside the range [0,11]„ in a 
digit position or a character outside the range [ ?2 17] 
in a sign position causes an illegal procedure fault.' 8 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or ml 
instructions causes an illegal procedure fault. 



mp3d 



Multiply Using Three Decimal Operands 



FORMAT: 



226 (1) 



Same as Add Using Three Decimal Operands (ad3d) 
(see Figure 4-28). 



SUMMARY: 



C(Y-charnl) X C(Y-charn2) -> C(Y-charn3) 



MODIFICATIONS: 
INDICATORS: 



None except au, qu, al, ql, xn for MF1 and MF2 
(Indicators not listed are not affected) 



Zero 

Negative 

Truncation 

Overflow 



Exponent 
overflow 

Exponent 
underflow 



If C(Y-charn3) = decimal 0, then ON; otherwise OFF 

If C(Y-charn3) is negative, then ON; otherwise OFF 

11 tn ® truncation condition exists without rounding, then 
ON; otherwise OFF (see NOTES) 

If the overflow condition exists, then ON; otherwise 
unchanged (see NOTES) lse 

If exponent of floating-point result exceeds 127 then 
ON; otherwise unchanged. 

If exponent of floating-point result is less than -128 
then ON; otherwise unchanged 



NOTES: 



If TN3 and S3 specify a 4-bit signed number and P = 1 
then the 13o plus sign character is placed appropriately 
if the result of the operation is positive. 

If N3 is not large enough to hold the integer part of the 
result as scaled by SF3, an overflow condition exists: 
the overflow indicator is set ON and an overflow fault 
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occurs. This implies that an unsigned fixed-point 
receiving field has a minimum length of 1 character; a 
signed fixed-point field, 2 characters; and a 
floating-point field, 3 characters. 

If N3 is not large enough to hold all the digits of the 
result as scaled by SF3 and R = 0, then a truncation 
condition exists; data movement stops when C(Y-charn3) is 
filled and the truncation indicator is set ON. If R = 1, 
then the last digit moved is rounded according to the 
absolute value of the remaining digits of the result and 
the instruction completes normally. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it ..tains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl), C(Y-charn2), and C(Y-charn3) may be 
overlapping strings; no check is made. 

If T = 1 and the truncation indicator is set ON by 
execution of the instruction, then a truncation (overflow) 
fault occurs. 

Detection of a character outside the range [0,11]o in a 
digit position or a character outside the range [T2,17] ft 
in a sign position causes an illegal procedure fault. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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EIS - Decimal Division 



dv2d 



Divide Using Two Decimal Operands 



FORMAT: 

SUMMARY: 

MODIFICATIONS: 

INDICATORS: 



207 (1) 



Same as Add Using Two Decimal Operands (ad2d) 
(see Figure 4-27). 

C(Y-charn2) /c(Y-charn1 ) -> C(Y-charn2) 

None except au, qu, al, ql, xn for MF1 and MF2 

(Indicators not listed are not affected) 



Zero 

Negative 

Overflow 



Exponent 
overflow 

Exponent 
Underflow 



If C(Y-charn2) = decimal 0, then ON; otherwise OFF 

If C(Y-charn2) is negative, then ON; otherwise OFF 

If the overflow condition exists, then ON: otherwise 
unchanged (see NOTES) otnerwise 

If exponent of floating-point result exceeds 127 then 
ON; otherwise unchanged. 

JLn e n P M° ner H ° f - floatin g-P°int result is less than -128 
then ON; otherwise unchanged 



NOTES: 



This instruction performs continued long division on the 

satis^fv 5 the^i "• h3S r° dUCe<i enOU * h out P ut ""«it a Eo 
n.™if Y * requirements of the quotient field. The 
number of required quotient digits, NQ, is determined 
before division begins as follows: nefl 

1) Floating-point quotient 

SviH.lH Z ',f1 Ut lf the , divisor ^ greater than the 
dividend after operand alignment, the leading zero 
digit produced is counted and the effective precision 
of the result is reduced by one. 

2) Fixed-point quotient 

NQ = (N2-LZ2+1) - (N1-LZ1) + (E2-E1-SF2) 



where: 



3) Rounding 



Nn 
LZn 
En 
SF2 



given operand field length 
leading zero count for operand n 
exponent of operand n ~ 
scaling factor of quotient 



If rounding is specified (R 
quotient digit is produced. 



= 1 ) , then one extra 
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If C(Y-charnl) = decimal or NQ > 63, then division does 
not take place, C(Y-charn2) are unchanged, and a divide 
check fault occurs. 

If TN2 and S2 specify a 4-bit signed number and P = 1 
then the 1 3q plus sign character is placed appropriately 
if the result of the operation is positive. 

If N2 is not large enough to hold the integer part of the 
result as scaled by SF2, an overflow condition exists; 
the overflow indicator is set ON and an overflow fault 
occurs. This implies that an unsigned fixed-point 
receiving field has a minimum length of 1 character- a 
signed fixed-point field, 2 characters; and' a 
floating-point field, 3 characters. 

If N2 is not large enough to hold all the digits of the 
result as scaled by SF2 and R = 0, then a truncation 
condition exists; data movement stops when C(Y-charn2) is 
filled and the truncation indicator is set ON. If R = 1 
then the last digit moved is rounded according to the 
absolute value of the extra quotient digit and the 
instruction completes normally. 

If MFk.RL = 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl) and C(Y-charn2) may be overlapping strings; no 
check is made. 

Detection of a character outside the range [0,11]o in a 
digit position or a character outside the range [T2,17] ft 
in a sign position causes an illegal procedure fault. 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 



dv3d 



Divide Using Three Decimal Operands 



227 (1) 



FORMAT: Same as Add Using Three Decimal Operands (ad3d) 

(see Figure 4-28) . 

SUMMARY: C(Y-charn2) /c(Y-charnl) -> C(Y-charn3) 

MODIFICATIONS: None except au, qu, al, ql , xn for MF1 and MF2 

INDICATORS: (Indicators not listed are not affected) 
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Zero If c(Y-charn3) = decimal 0, then ON; otherwise OFF 

Negative If c(Y-ohar„3> Is negative, then ON; otherwise OFF 

0, ' rfl °" u„ f oha„gea OV <re f e 1O »'0T E 5T ditl0 " °^ "»» °»> •*"•"-» 

unKl'ow th^^^he^ls^ro'h"^ 1 " 1 """ " X " S '»" -' 28 



NOTES: 



This instruction performs continued long division on the 

satis??" til" 1 " haS , produced -nouah Output digits 'to 
satisfy the requxreraents of the quotient field The 
number of required quotient digits, NQ is determined 
before division begins as follows! determined 

1) Floating-point quotient 

dividJfrf 3, »£ Ut lf the divisor " greater than the 
dlaiJ nJnn !T - 0perand alignment, the leading zero 
digit produced is counted and the effective precision 
of the result is reduced by one. 

2) Fixed-point quotient 

NQ = (N2-LZ2+1) - (N1-LZ1) ♦ (E2-E1-SF3) 

where: Nn = given operand field length 

LZn = leading zero count for operand n 
En = exponent of operand n ~ 
SF3 = scaling factor of quotient 

3) Rounding 

If rounding is specified (R = 1), then one eyt-ra 
quotient digit is produced. a 

i£^ CC Y-ctiar-n 1 3 = decimal or NQ > 63, then division does 
c n ^c k ta f k a e ult la o C ccurs C . (Y - Cha ^ 3) »" UBCh """' ^ * "*"• 

ILI^L 3nd . S3 n s P ecif v a 4 ~bit signed number and P = 1 
then the 13- plus sign character is placed appropriately 
if the resuft of the operation is positive. °Priazeiy 

If N3 is not large enough to hold the integer part of the 

L a n SOae , d - b ! SF3 ' an overflow condition exists? 
the overflow indicator is set ON and an overflow fault 
occurs. This implies that an unsigned fixed-point 

J?« 1 H ln8 / l6 i d h3S a minimUm len 8 th of 1 character; a 
signed fixed-point field, 2 characters; and a 

floating-point field, 3 characters. 

If N3 is not large enough to hold all the digits of the 
"" . as sca i ed ^ SF3 and R = 0, then a 8 truncation 
condition exists; data movement stops when C(Y-charn3) is 
tilled and the truncation indicator is set ON. If R - 1 
then the last digit moved is rounded according to "the 
absolute value of the extra quotient digit and the 
instruction completes normally. 
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If MFk.RL s 1, then Nk does not contain the operand 
length; instead, it contains a register code for a 
register holding the operand length. 

If MFk.ID = 1, then the kth word following the instruction 
word does not contain an operand descriptor; instead, it 
contains an indirect pointer to the operand descriptor. 

C(Y-charnl), C(Y-charn2), and C(Y-charn3) may be 
overlapping strings; no check is made. ~ 

Detection of a character outside the range [0,1 1]« in a 
digit position or a character outside the range C T 2 , 1 7 ] p 
in a sign position causes an illegal procedure fault. ' 

Attempted execution with the xed instruction causes an 
illegal procedure fault. 

Attempted repetition with the rpt, rpd, or rpl 
instructions causes an illegal procedure fault. 
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The Move Alphanumeric Edited (mve) and Move Numeric Edited (mvne) 
instructions require micro operations to perform the editing functions in an 
eiticient manner. The sequence of micro operation steps to be executed is 
contained m main memory and is referenced by the second operand descriptor of 
the mve or mvne instructions. Some of the micro operations require special 
characters for insertion into the string of characters being edited. These 
special characters are shown in the "Edit Insertion Table" discussion below. 

Micro Operation Sequence 

The micro operation string operand descriptor points to a string of 9-bit 
bytes that specify the micro operations to be performed during an edited move, 
bach of the 9-bit bytes defines a micro operation and has the following format- 




Figure 4-29. Micro Operation (MOP) Character Format 



MOP 

IF 



5-bit code specifying the micro operator 
Information field containing one of the following: 

1) A sending string character count. A value of is 
interpreted as 16. 

2) The index of an entry in the edit insertion table to 
be used. Permissible values are 1 through 8. 



3) An interpretation of the "blank-when-zero" operati 



Lon 



Edit Insertion Table 

While executing an edit instruction, the processor provides a register of 
eight 9-bit bytes to hold insertion information. This register, called the edit 
insertion table, is not maintained after execution of an edit instruction. At 
the start of each edit instruction, the processor initializes the table to the 
values given in Table 4-8, where each symbol refers to the corresponding 
standard ASCII character. 
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Table 4-8. Default Edit Insertion Table Characters 



Table Entry 




Number 


Character 


1 


blank 


2 


* 


3 


+ 


4 


_ 


5 


$ 


6 


t 


7 


* 


8 


(zero) 



One or all of the table entries can be changed by the Load Table Entry 
(lte) or the Change Table (cht) micro operations to provide different insertion 
characters. 



Edit Flags 

The processor provides the following four edit flags for use by the micro 
operations. 



ES 



SN 



BZ 



End suppression flag; initially OFF and set ON by a micro 
operation when zero suppression ends. 

Sign flag; initially set OFF if the sending string is 
alphanumeric or unsigned numeric. If the sending string 
is signed numeric, the sending string sign character is 
tested and SN is set OFF if positive, and ON if negative. 

Zero flag; initially set ON. It is set OFF whenever a 
sending string character that is not decimal zero is moved 
into the receiving string. 

Blank-when-zero flag; initially set OFF and is set ON by 
either the enf or ses micro operation. If, at the 
completion of a move, both the Z and BZ are ON, the 
receiving string is filled with character 1 of the edit 
insertion table. 



Terminating Micro Operations 

The micro operation sequence is terminated normally when the receiving 
string length becomes exhausted. The micro operation sequence is terminated 
abnormally (with an illegal procedure fault) if a move from an exhausted sending 
string or the use of an exhausted MOP string is attempted. 
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MVNE and MVE Differences 

The processor executes mvne in a slightly different manner than it executes 
mve. This is due to the inherent differences in the way numeric and 
alphanumeric data are handled. The following are brief descriptions of the 
hardware operations for mvne and mve. 



NUMERIC EDIT 

1. Load the entire sending string number (maximum length 63 characters) 
into the decimal unit input buffer as 4-bit digits (high-order 
truncating 9-bit data). Strip the sign and exponent characters (if 
any), put them aside into special holding registers and decrease the 
input buffer count accordingly. 

2. Test sign and, if required, set the SN flag. 

3. Execute micro operation string, starting with first (4-bit) digit. 

4. If an edit insertion table entry or MOP insertion character is to be 
stored, vANDed, or ORed into a receiving string of 4- or 6-bit 
characters, high-order truncate the character accordingly. 

5. If the receiving string is 9-bit characters, high-order fill the 
(4-bit) digits from the input buffer with bits 0-4 of character 8 of 
the edit insertion table. If the receiving string is 6-bit 
characters, high-order fill the digits with "00"b. 



ALPHANUMERIC EDIT 

1. Load decimal unit input buffer with sending string characters. Data 
is read from main memory in unaligned units (not modulo 8 boundary) of 
Y-block8 words. The number of characters loaded is the minimum of the 
remaining sending string count, the remaining receiving string count, 
and 64. 

2. Execute micro operation string, starting with the first receiving 
string character. 

3- If an edit insertion table entry or MOP insertion character is to be 
stored, ANDed, or ORed into a receiving string of 4- or 6-bit 
characters, high-order truncate the character accordingly. 



Micro Operations 

A description of the 17 micro operations (MOPs) follows. The mnemonic, 
name, octal value, and the function performed is given for each MOP in a format 
similar to that for processor instructions. These micro operations are included 
in the alphabetic list of instructions in Appendix B, identified by the code 
MOP. 

Checks for termination are made during and after each micro operation. All 
MOPs that make a zero test of a sending string character test only the four 
least significant bits of the character. 
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The following additional abbreviations and symbols are used in the descriptions 
of the MOPs. 

EIT edit insertion table 

pin current position in the sending string 

pmop current position in the micro operation string 

pout current position in the receiving string 

After each MOP, add one to pmop. 



cht 



Change Table 



21 



SUMMARY: 



For i = 1, 2, . . . , 8 

C(Y-char92) pmop+i -> C(EIT) i 
pmop s pmop + 8 



FLAGS : 



None affected 



NOTES: 



C(IF) is not interpreted for this operation. 



enf 



End Floating Suppression 



02 



SUMMARY: 



If C(IF) = 0, then 
If ES is OFF, then 

If SN is OFF, then C(EIT> 3 -> C(Y-charn3) pout 1 
If SN is ON, then C(EIT)i, -> C(Y-charn3) pout | 
pout = pout + 1 
ES set ON 
If ES is ON, then no action 
If C(IF) = 1, then 
If ES is OFF, then 

C(EIT) 5 -> C(Y-charn3) pout | 

pout = pout + 1 
ES set ON 
If ES is ON, then no action 
If C(IF) 1 = 1, then BZ set ON; otherwise no action 



V82 
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FLAGS: 



ES 
BZ 



(Flags not listed are not affected) 

If OFF, then set ON 

If C(IF) 1 = 1, then set ON; otherwise no change 



ign 



Ignore Source Character 



SUMMARY: 



pin = pin + C(IF) 



14 



FLAGS: 



None affected 



insa 



Insert Asterisk on Suppression 



SUMMARY: 



FLAGS: 



NOTES: 



1 1 



If ES is OFF, then 

C(EIT) 2 -> C(Y-charn3) pout 
If C(IF) = 0, then pmop = pmop 
If ES is ON, then 

If C(IF) i 0, then 
m = C(IF) 

C(EIT) n -> C(Y-charn 3 ) pout 
If C(IF) = 0, then 

C(Y-char92) pmop+1 -> C(Y-charn3) pout 
pmop = pmop + 1 
pout = pout + 1 

None affected 

If C(IF) > 8 an illegal procedure fault occurs. 



2/82 
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insb 



Insert Blank on Suppression 



10 



SUMMARY: 



If ES is OFF, then 

CCEIT), -> C(Y-charn3) pout 
If C(IF) = 0, then pmop = pmop + 1 
If ES is ON, then 

If C(IF) 4 0, then 
m = C(IF) 

C(EIT) m -> C(Y-charn3) pout 
If C(IF) = 0, then 

C(Y-char92) pmop+1 -> C(Y-charn3> pout 
pmop = pmop + 1 
pout = pout + 1 



I 
I 
I 



FLAGS : 
NOTES: 



None affected 



If C(IF) > 8 an illegal procedure fault occurs. 



insm 



Insert Table Entry One Multiple 



01 



SUMMARY : 



For i = 0, 1, ..., C(IF) - 1 

CKEIT), -> C(Y-charn3) pout+1 
pout s pout + C(IF) 



FLAGS: 



None affected 



1 



insn 



Insert On Negative 



12 



SUMMARY: 



If SN is OFF, then 

C(EIT) 1 -> C(Y-charn3) pout 

If C(IF) = 0, then pmop s pmop 

If SN is ON, then 

If C(IF) 4 0, then 



+ 1 



■/82 
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m = C(IF) 

C(EIT) m -> C(Y-charn3) pout 
If C(IF) = 0, then 

C(Y-char92) pmop+1 -> c(Y-charn3 ) pout 
pmop = pmop + 1 
pout = pout + 1 



FLAGS: 
NOTES: 



None affected 



If C(IF) > 8 an illegal procedure fault occurs. 



insp 



Insert On Positive 



SUMMARY: 



FLAGS: 
NOTES: 



13 



If SN is ON, then 

C(En) } -> C(Y-charn3) pout 
If C(IF) = 0, then pmop = pmop + 1 
If SN is OFF, then 
If C(IF) i 0, then 
m = C(IF) 

C(EIT) m -> C(Y-charn3) pout 
If C(IF) = 0, then 

C(Y-char92) pmop+1 -> C(Y-eharn3> pout 
pmop = pmop + 1 
pout s pout + 1 

None affected 

If C(IF) > 8 an illegal procedure fault occurs. 



lte 



Load Table Entry 



SUMMARY: 



20 



1 



m = C(IF) 

C(Y-char92) pmop+1 -> C(En) m 

pmop = pmop + 1 
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FLAGS : 



None affected 



NOTES: 



If C(IF) = or C(IF) > 8 an illegal procedure fault occurs. 



mflc 



Move with Floating Currency Symbol Insertion 



07 



SUMMARY: 



For i = 0, 1, .... C(IF) - 1 | 

If ES is ON, then C(Y-charn1 ) pin+1 -> C(Y-eharn3) pout+i 
If ES is OFF and C(Y-eharnJ) in+i = decimal 0, then 

C(EIT)., -> C(Y-charn3) pout+1 
If ES is OFF and C(Y-charn1 ) pin+i d decimal 0, then 
C(EIT) 5 -> C(Y-charn3) pout+i 
C(Y-charn1) pin+i -> C(Y-charn3> pout+1+1 
pout = pout + 1 
ES set ON 
pin r pin + C(IF) I 

pout = pout + C(IF) I 



FLAGS: 

ES 
Z 
NOTES: 



(Flags not listed are not affected) 



If OFF and any of C(Y-charn1 ) pin+i 4 decimal 0, then ON; 
otherwise unchanged 

See the "Edit Flags" section. 



The number of characters moved to the receiving string is 
data dependent. If the entire C(Y-charnl) are decimal 0s, 
C(IF) characters are moved to C(Y-charn3). However, if 
the sending string contains a non-zero character, then C(IF) + 1 
characters are moved to C(Y-charn3); the insertion character 
plus C(Y-charnl). A possible illegal procedure fault due 
to this condition may be avoided by assuring that the Z 
and BZ flags are ON. 



mfls 



Move with Floating Sign Insertion 



06 



SUMMARY: 



For i = 0, 1, ..., C(IF) - 1 | 

If ES is ON, then C(Y-charn1 ) pirl+i -> C(Y-charn3) pout+i 
If ES is OFF and C(Y-charn1 ) pin+i = decimal 0, then 
C(EIT)., -> C(Y-charn3) pout+i 
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If ES is OFF and C(Y-charnl) pin+1 i decimal 0, then 
If SN is OFF, then C(EIT> 3 -> C(Y-charn3 ) pout+i 
If SN is ON, then C(EIT) 4 -> C( Y-charn3) pout+i 
C(Y-charn1) pin+l -> C(Y-charn3) pout+l+1 

pOUt a pout + 1 

ES set On 
pin = pin + C(IF) 
pout = pout + C(IF) 



FLAGS: 



(Flags not listed are not affected) 



ES 



If OFF and any of C(Y-charn1 ) pln+i * decimal 0, then ON; 
otherwise unchanged 

See the "Edit Flags" section 



NOTES: 



The number of characters moved to the receiving string is 
data dependent. If the entire C(Y-charnl) are decimal 0s, 
C(IF) characters are moved to C(Y-charn3). However, if 
the sending string contains a non-zero character, then C(IF)+1 
characters are moved to C(Y-charn3); the insertion character 
plus C(Y-charnl). A possible illegal procedure fault due 
to this condition may be avoided by assuring that the Z 
and BZ flags are ON. 



mors 



Move and OR Sign 



17 



SUMMARY: 



For i = 0, 1, .... C(IF) - 1 
If SN is OFF, then 

C(Y-charn1) pln+i | c(EIT> 3 -> C(Y-charn3) pout+1 
If SN is ON, then 

C(Y-charn1) pin+i ! C(EIT)j, -> C(Y-charn3) pout+1 
pin = pin + C(IF) 
pout a pout + C(IF) 



FLAGS: 
Z 



(Flags not listed are not affected) 
See the "Edit Flags" section 
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mses 



Move and Set Sign 



16 



SUMMARY: 



FLAGS : 



For mvne 

For i = 0, 1, ..., C(IF) - 1 

C(Y-charn1) pln+i -> C(Y-charn3) pout+i 
pin = pin + C(IF> 
pout = pout + C(IF) 
For mve 

C(Z) = 

For i = 0, 1 C(IF) - 1 

C(Y-charn 1 ) pin+i -> C(Y-charn 3 ) pout+i 
If C(Z) = 0, then 

C(Z) = C(Y-charn1) pln+i & C(EIT) 3 
If C(Z) = 0, then 

C(Z) = C(Y-eharn1) pln+i & C(EIT) 4 
If C(Z) i 0, then SN set ON 
pin s pin + C(IF) 
pout = pout + C(IF) 

(Flags not listed are not affected) 



SN 
Z 



If C(EIT)j, found in C(Y-eharnl), then ON; otherwise no 
change 

See the "Edit Flags" section 



mvc 



Move Source Characters 



15 



SUMMARY: 



FLAGS : 
Z 



For i = 0, 1, .... C(IF) - 1 

C(Y-charn1) pin+l -> C(Y-charn3) pout+i 
pin = pin + C(IF) 
pout = pout + C(IF) 

(Flags not listed are not affected) 
See the "Edit Flags" section 
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mvza 



Move with Zero Suppression and Asterisk Replacement 



05 



| SUMMARY: 



For i = 0, 1, .. ., C(IF) - 1 

If ES is ON, then C(Y-charn1 ) pin+i -> C(Y-charn3 ) pout+1 
If ES is OFF and C(Y-charn1 ) pin+1 = decimal 0, then 

C(EIT) 2 -> C(Y-charn3) pout+i 
If ES is OFF and C(Y-eharn1 ) pln+i jJ decimal 0, then 
C(Y-charn1) pln+i -> C(Y-charn3) pout+1 
ES set On 
pin = pin + C(IF) 
pout = pout + C(IF) 



FLAGS: 



(Flags not listed are not affected) 



ES 



If OFF and any of C(Y-charn1 ) in+i d decimal 0, then ON; 
otherwise unchanged 

See the "Edit Flags" section 



mvzb 



Move with Zero Suppression and Blank Replacement 



04 



SUMMARY: 



For i = 0, 1, .. . , C(IF) - 1 

If ES is ON, then C(Y-charn1 ) pin+i -> C(Y-charn3) pout+i 
If ES is OFF and C(Y-charn1 ) pin+1 = decimal 0, then 

CCEIT), -> C(Y-charn3) pout+1 
If ES is OFF and C(Y-charn1 ) pln+1 i decimal 0, then 
C(Y-charn1) pln+i -> C(Y-charn3) pout+i 
ES set ON 
pin = pin + C(IF) 
pout = pout + C(IF) 



FLAGS: 



(Flags not listed are not affected) 



ES 



If OFF and any of C(Y-charnl) ± ± 4 decimal 0, then ON; 
otherwise unchanged y 

See the "Edit Flags" section 
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ses 



Set End Suppression 



03 



SUMMARY: 



If C(IF) s 0, then ES set OFF 

If C(IF) = 1, then ES set ON 

If C(IF) 1 s 1, then BZ set ON; otherwise no action 



FLAGS: 



(Flags not listed are not affected) 



ES 
BZ 



Set by this micro operation 

If C(IF) 1 s 1, then ON; otherwise no change 



Micro Operation Code Assignment Map 

Operation code assignments for the micro operations are shown in Table 4-9. 

A dash ( ) indicates an unassigned code. All unassigned codes cause an illegal 

procedure fault. 



Table 4-9. Micro Operation Code Assignment Map 
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SECTION 5 
ADDRESSING — SEGMENTATION AND PAGING 



ADDRESSING MODES 



The Multics processor is able to access the main memory in either absolute 
mode or append mode. The processor prepares an 18-bit computed address (TPR.CA) 
for each main memory reference for instructions or operands using the address 
preparation algorithms described in Section 6. This computed address is a 
scalar index into a virtual memory with an extent of 262, 144 words. 

Absolute Mode 

In absolute mode, the appending unit is bypassed for instruction fetches 
and most operand fetches and the final 18-bit computed address (TPR.CA) from 
address preparation becomes the absolute main memory address. 

Thus, all instructions to be executed in absolute mode must reside in the 
i^""?«2 er 262,144 words of main memory, that is, main memory addresses through 
262,143. Operands normally also reside in the low-order 262,144 words of main 
memory but, by specifying in an instruction word that the appending unit be used 
for the main memory access, operands may reside anywhere in main memory. An 
appended operand fetch may be specified by: 



1 



Specifying register then indirect (ri) address modification in the 
instruction word and indirect to segment (its) or indirect to pointer 
dtp) address modification in the indirect word. 

2. Specifying pointer register modification in the instruction word 
(bit 29 =1) and giving a pointer register number in the instruction 
address C(y) Q 2 . 

3- Specifying pointer register modification (MFk.AR =1) in the 
modification field for an EIS operand descriptor. ~ 

The use of any of the above constructs in absolute mode places the 
processor in append mode for one or more address preparation cycles All 
necessary registers must be properly loaded, all tables of segment descriptor 
words (SDWs) and page table words (PTWs) expected by the appending unit must 
exist and be properly described, and all fault conditions must be considered 
(see append mode below). 

If a transfer of control is made with any of the above constructs, the 
processor remains in append mode after the transfer and subsequent instruction 
fetches are made in append mode. 
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vi SU anze°a g vir n tn a f gment ^ defined for »»solut« mode, 
memory ^rtual, unpaged segment overlaying the first 



it may be helpful to 
262,144 words of main 



Append Mode 



r.<-Z^r%.7£i»2; JlTX'Sl.^ iUJtfVZ, '£, t £. »'» ~" 



SEGMENTATION 



size o? .ISiVaV '-o^rSSinVng'Vrirtr.S iVT ° f ^'^ (bUt U » lted > 
the processor by a ..g-Bt'SSir'Si^oTuSlj!!; to" KU^^^^ Mithln 

is not° dMoftbS 'auUgr^^'an'Lte^al' " ? f J h « »».Pdw.r. ring mechanism 
Section 8 for a discussion of the Tin " ^f LlA d . dreS3 Preparation. See 



of the ring mechanism hardware. 




2. Fetch the target segment SDW from DSBR.ADDR + 2 » segno. 

3 ' SDW S F D C W ' F tL°: i the " generate directed fault n where n is given in 

'• o U f t O o f f fS 3 % t 8 „ > ;„ t 16 , o * un ( !fr-f B a uT.* "• ,h " «""■"'• » ""» "<*■«•». 

5. If the access bits (SDW.R snw r «i- n i „* <. u 

6. Generate 24-bit absolute main memory address SDW.ADDR + offset. 
Figure 5-1 depicts the relationships just described. 
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descriptor 
segment 



2 * segno 

target + 
segment 



offset 



data 




<- 



DSBR.ADDR 



SDW( segno) 



16 * (DSBR.BND + 1) 



16 • (SDW. BOUND + 1) 



Figure 5-1. Main Memory Address Generation for Unpaged Segment: 



PAGING 



,10 



o«u n Hulties, a -page is defined as a block of virtual memory with a size of 
2 machine words. The processor is designed in such a way that the page size 
is adjustable over the range [2 6 ,2 r? ] but no basis has been found to justify an 
assertion that any page size is more efficient than 2 10 or 1024 words. 



The processor divides a k-bit offset or segno value into two parts; the 
high-order (k-n) bits forming a page number, x, and the low-order n bits forming 
a word number, y. This may stated as: B 

y = (value) modulo (page size) ' 

x = (value - y) / (page size) 



The symbols x and y are used in this context throughout this section, 
example of page number formation is shown in Figure 5-2. 
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Figure 5-2. Page Number Formation 
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w>* i, m the SDW for a segment (SDW.U) specifies whether the segment is 

limit J, u " pa 8 ed - A paged segment may be defined as an array of arbitrary (but 

words Th»r ? ,f ag6S a r d 3 - P , age may be defi ned as ■ an array of 1024 machine 

into th« ™ -„h , 3 S< V Xn t ex int ° the array of pages ' y is a scalar ind ^ 
r£f2r»n^ P ?« * ? reference to a word of a paged segment may be treated as a 
reference to word y of page x of the segment. 

, aph Hul l^ ! Ubdl wi? e ? - the v * rtual memory into page size blocks of 1024 words 
each. Such a subdivision of space allows a segment page to handled as a 
SS"°.i bl ?° k lnde P end «ntly from the other pages of the segment and from other 
segments. In main memory, the blocks are known as frames; on secondary storage 
they are known as records. When a reference to a word in a paged segment is 
required (and the page containing the word is not already in main memory), a 
n^lJUT^ frame „ 1S allocated and the page is read in from secondary storage. 
Unneeded pages need not occupy space in main memory. 

„„,.,, Th , e lo f a w, ion , and status of P a Se x of a paged segment is kept in the x tn 
word of a table known as the page table for the segment. The words in this 
table are known as page table words (PTWs) (see Figure 5-6). 

Any segment may be paged as appropriate and convenient. The address field 
%{ kA 6 ,f egme nt descriptor word (SDW.ADDR) for a paged segment contains the 
ll aa Ut ? "J 31 " memorv address of the page table for the segment instead of 

the address of the origin of the segment. If the descriptor segment is paged, 
t* %,, k*! S ( leld o f the descriptor segment base register (DSBR.ADDR) contains 
trie 24-bit absolute main memory address of the page table for the descriptor 
segment. 

The full algorithm used by the processor to access word offset of paged 
segment segno (including descriptor segment paging) is as follows. (Refer to 
Figures 2-14, 5-5, and 5-6.) 

1. If 2 * segno >= 16 * (DSBR.BND +1), then generate an access 
violation, out of segment bounds, fault. 

2. Form the quantities: 

y1 = (2 * segno) modulo 1024 
x1 = (2 * segno - y1) / 1024 

3. Fetch the descriptor segment PTW(x1) from DSBR.ADR + x1. 

4. If PTW(x1).F = 0, then generate directed fault n where n is given in 
PTW(x1).FC. The value of n used here is the value assigned to define 
a missing page fault or, simply, a page fault. 

5. Fetch the target segment SDW, SDW(segno), from the descriptor segment 
page at PTW(x1).ADDR + y1. 

6. If SDW(segno).F = 0, then generate directed fault n where n is given 
in SDW(segno) .FC. This is a segment fault as discussed earlier in 
this section. 

7. If offset >= 16 * (SDW(segno). BOUND + 1), then generate an access 
violation, out of segment bounds, fault. 

8. If the access bits (SDW(segno) .R, SDW(segno) .E, etc.) of the segment 
are incompatible with the reference, generate the appropriate access 
violation fault. 

9. Form the quantities: 

y2 = offset modulo 1024 
x2 = (offset - y2) / 1024 
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10. Fetch the target segment PTW(x2) from SDW(segno) .ADDR + x2. 

11. If PTW(x2).F = 0, then generate directed fault n where n is given in 
PTW(x2).FC. This is a page fault as in Step 4 above. 

12. Generate the 24-bit absolute main memory address PTW(x2).ADDR + y2. 
Figure 5-3 depicts the relationships described above. 



yi 

x1 

y2 

x2 



(2*segno) modulo 1024 
(2*segno-y1) / 1024 
offset modulo 1024 
(offset-y2) / 1024 



descriptor 
segment 
page table 



descriptor 
segment 
page 



T 

X1 



target 
segment 
page table 



SDW(segno) 



target 

segment 

page 





DSBR.ADDR 



PTW(x1) 



1024 



1024 



Figure 5-3. Main Memory Address Generation for Paged Segments 



CHANGING ADDRESSING MODES 



The processor is placed in absolute mode by the initialize, initialize and 
clear, or system initialize functions. The first response to faults and 
interrupts is in absolute mode and the mode thereafter is determined by the 
instruction sequence entered through the fault or interrupt trap pair. The 
processor remains in absolute mode until a transfer of control via the appending 
unit takes place. Note that a Return (ret) or Restore Control Unit (rcu) 
instruction that sets the absolute indicator OFF (see Section 3 for. a discussion 
of the indicators) or a Return Control Double (rtcd) instruction also places the 
processor in append mode. 

When it responds to a fault or interrupt, the processor enters absolute 
mode temporarily for the fetch and execution of the trap pair. If an unappended 
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T e Sr t[ h lrJs! C Lt e r^uX\\ in thS ^ aP , Pair ' the Pressor remains in absolute 
ae , otnerwise it returns to append mode. 



transfer 

mo 



ADDRESS APPEMDING 



Section 6? an ??#*?, *\ e for u mati , on of the virtual memory address (see 
Section 6) an effective segment number (segno) is in the segment number register 
of the temporary pointer register (TPR.SNR) and a computed address (offslt) is 
in the computed address register of the temporary pointer register (TPRCA) 
(See Section 3 for a discussion of the temporary pointer register ) tTPR ' CA - } 

Address Appending Sequences 

Once segno and offset are formed in TPR.SNR and TPR.CA, respectively the 
process of generating the 24-bit absolute main memory address can involve a 
number of different and distinct appending unit cycles. involve a 

* a Th T e h^ Pe p7 ti0 .r °J the a PP endin 8 unit is shown in the flowchart in Figure 
fa"uits do not 1 oc'cuV a, : t aSSUmeS th3t dir6Cted f3UltS ' St ° re faultS ' and ^y 

A segment boundary check is made in every cycle except PSDW. If a boundarv 
«£«£S «„ d , 6 H teCted ' . 3n aCC6SS viola tion, out of segment bounds, fault Is 
!nC r«Vl , 6 ? xe 1 utlon of th e instruction interrupted. The occurrence of 
any fault interrupts the sequence at the point of occurrence. The operating 
system software should store the control unit data for possible laS 
continuation and attempt to resolve the fault condition. P iater 

The value of the associative memories may be seen in the flowchart bv 
observing the number of appending unit cycles bypassed if an SDW or PTW is found 
in the associative memories. 

There are nine different appending unit cycles that involve accesses to 

add'r.sT ^- i T ,?. °/ these .< FANP > FAP) generate the 24-bit absolute ma "memory 
address and initiate a mam memory access for the operand, indirect word or 

i2S« ii r P3 i r; f SS (NSDW ' PSDW ' PTW ' PTW ' and DSPTW) generate a main memory 
access to fetch an SDW or PTW; and two (MDSPTW and MPTW) generate a main memory 
access to update page status bits (PTW.U and PTW.M) in a PTW. The cycles are 
del ined in Table 5-1. 
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Table 5-1. Appending Unit Cycle Definitions 



Cycle 
name 



Function 



FANP Final address nonpaged 

Generates the 24-bit absolute main memory address and initiates a 
main memory access to an unpaged segment for operands, indirect 
words, or instructions. 

FAP Final address paged 

Generates the 24-bit absolute main memory address and initiates a 
main memory access to a paged segment for operands, indirect words, 
or instructions. 

NSDW Nonpaged SDW Fetch 

Fetches an SDW from an unpaged descriptor segment. 
PSBW Paged SDW Fetch 

Fetches an SDW from a paged descriptor segment. 
PTW PTW fetch 

Fetches a PTW from a page table other than a descriptor segment page 
table and sets the page accessed bit (PTW.U). 

PIW2 Prepage PTW fetch 

Fetches the next PTW from a page table other than a descriptor 
segment page table during hardware prepaging for certain 
uninterruptable EIS instructions. This cycle does not load the 
next PTW into the appending unit. It merely assures that the . PTW 
is not faulted (PTW.F = 1) and that the target page will be in main 
memory when and if needed by the instruction. 

DSPTW Descriptor segment PTW fetch 

Fetches a PTW from a descriptor segment page table. 

MDSPTW Modify DSPTW 

Sets the page accessed bit (PTW.U) in the PTW for a page in a 
descriptor segment page table. This cycle always immediately 
follows a DSPTW cycle. 

MPTW Modify PTW 

Sets the page modified bit (PTW.M) in the PTW for a page in other 
than a descriptor segment page table. 
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Figure 5-4. Appending Unit Operation Flowchart 
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APPENDING UNIT DATA WORD FORMATS 



Segment Descriptor Word (SDW) Format 

The segment descriptor word (SDW) pair contains information that controls 
the access to a segment. The SDW for segment n is located at offset 2n in the 
descriptor segment whose description is currently loaded into the descriptor 
segment base register (DSBR). 

Even word 
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Figure 5-5. Segment Descriptor Word (SDW) Format 



Field Name Description 

ADDR 24-bit absolute main memory address of unpaged segment (U=1) 
or segment page table (U=0) 

R1,R2,R3 Ring brackets (see Section 8) 

F Directed fault flag 

1 = the unpaged segment or segment page table is in main 

memory 
= execute the directed fault specified in FC 

FC The number of the directed fault (df0-df3) to be executed if 
F=0 

BOUND 14 high-order bits of the largest 18-bit modulo 16 offset that 
may be accessed without causing a descriptor violation, out of 
segment bounds, fault 
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Field Name 
R 
E 
W 
P 



EB 



Description 

Read permission bit 

Execute permission bit (xec and xed instructions excluded) 

Write permission bit 

Privileged mode bit 

= privileged instructions cannot be executed 

1 = privileged instructions may be executed if in ring 

Paged/unpaged control bit 

= segment is paged; ADDR is the 24-bit main memory 

address of the page table 

1 = segment is unpaged; ADDR is the 24-bit main memory 

address of the origin of the segment 

Gate indicator bit 

= any call into the segment must be to an offset less 

than the value of EB 

1 = any legal segment offset may be called 

Cache control bit 

= words (operands or instructions) from this segment may 

not be placed in the cache memory 

1 = words from this segment may be placed in the cache 

memory 

Entry bound 

Any call into this segment must be to an offset less than EB 
if G=0 



Page Table Word (ptw) Format 

The page table word (PTW) contains main memory address and status 
information for a page of a paged segment. 



ADDR 
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Figure 5-6. Page Table Word (PTW) Format 



Bits pictured as "x" are ignored by the hardware and may be used by the 
operating system software. 
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Field Name Description 

ADDR 18-bit modulo 64 absolute main memory address of page 

The hardware ignores low order bits of the main memory page 
address according to page size based on the following: 

Page Size 
in words 

— m — 

128 

256 

512 
1024 
2048 
4096 

U 1 = page has been used (referenced) 

M 1 = page has been modified 

F Directed fault flag 

1 = page is in main memory 

= page not in main memory; execute directed fault FC 

FC directed fault number for page fault. 



ADDF 


t Bits 


ignored 


none 
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SECTION 6 
VIRTUAL ADDRESS FORMATION 



DEFINITION OF VIRTUAL ADDRESS 

The virtual address in the Multics processor is the user's specification of 
the location of a data item in the Multics virtual memory. Each reference to 
the virtual memory for operands, indirect words, indirect pointers, operand 
descriptors, or instructions must provide a virtual address. The hardware and 
the operating system translate the virtual address into the true location of the 
data item and assure that the data item is in main memory for the reference. 

The virtual address consists of two parts, an effective segment number and 
an offset or computed address. The value of each part is the result of the 
evaluation of a hardware algorithm (expression) of one or more terms. The 
selection of the algorithm is made by the use of control bits in the instruction 
word; for example, bit 29 for modification by pointer register and bits 30-35 
(the TAG field) for modification by index register or indirect word. For 
certain modifications by indirect word, the TAG field of the indirect word is 
also treated as an address modifier, thus establishing a continuing "indirect 
chain". Bit 29 of an indirect word has no meaning in the context of virtual 
address formation. 

The results of evaluation of the virtual address formation algorithms are 
stored in temporary registers used as working registers by the processor. The 
effective segment number is stored in the temporary segment register, TPR.TSR. 
The offset is stored in the computed address register, TPR.CA. When each 
virtual address computation has been completed, C(TPR.TSR) and C(TPR.CA) are 
presented to the appending unit for translation to a 24-bit absolute main memory 
address (see Section 5). 



TYPES OF VIRTUAL ADDRESS FORMATION 

There are two types of virtual address formation. The first type does 
not make explicit use of segment numbers. The algorithms produce values for the 
computed address, C(TPR.CA), only. The effective segment number in C(TPR.TSR) 
does not change from the value used to fetch the current instruction. In this. 
case, all references are said to be "local" to the procedure segment pointed to' 
by the procedure pointer register (PPR). 

The second type makes use of a segment number in an indirect word-pair in 
main memory or in a pointer register (PRn). The algorithms produce values for 
both the effective segment number, C(TPR.TSR), and the computed address, 
C(TPR.CA). The effective segment number in C(TPR.TSR) may change and, if it 
changes, references are said to be "external" to the procedure segment. 

Both types of virtual address formation for the operand of a basic or EIS 
single-word instruction begins with a preliminary step of loading TPR.CA with 
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d^nr^/e^nrecoL 6 /"^^ 10 " "^ ThiS ^^ step ta.es place 

»h5n? ? rS ° r indirect Mords > e ach virtual address is translated to a 24-bit 
absolute mam memory address to fetch the next item in the chain? 

™™!!™H- deSC J" if t t u ion of virtual address formation is divided into two parts 
esp ° n ^ n 8 fo the t wo types. The first part describes the type that invSlIw 
In "aooend Z£ ed addre ? s > C(TPH.CA). The effective segment number is coSs?ant 

2.o?u^»s d ^ i v.i:: 1 !t:„Vd.Hffi. to C(PPR - PSR) (a local reference) and in 

nu-bJ^S^.^ «. Effective segment 

SYMBOLOGY (ALM) 

featulls m o? Y t*? S \^ Ce L«L\, the discussions th ^ follow, references to the 
reatures of the ALM assembly program are unavoidable. Such references are 
explained briefly here. The reader is advised to consult thf appropriate 

;arious%e a ?u U r m es n . tati0n f ° P fUrth6r d6tailS a " d f ° r posSible oh.ngS ?n "K 
Symbolic Fields 

m-.rJi. aym ifH liC fie - ld is . u a " expression consisting of variables, constants, 

corresponding rllli Hr 1 k- evalua * ed ** ALM to Produce a value for the 

corresponding field of a machine word. The values of the variables and 
constants are either known or assignable and the operators are defined for the 
:°* of t«e evaluation (algebraic, logical, etc.)/ The necessary fields for a 
^rlnro/^e^ns!'' ^ >—*>-*■"".•«« are given as a /omma- separated 



Aim Pseudo-Instructions 

The following ALM pseudo-instructions are used in this sections: 
aci string 

This pseudo-instruction generates a sequence of 9-bit byte fields each 
of which contains the ASCII octal value for the corresponding graphic 
character in. string. The last machine word generated is low-order 
filled with binary Os to the next word boundary. 

arg address , tag 

This pseudo-instruction generates a machine word with the same format 
as the basic and EIS single-word instructions but having binary Os in 
the operation code field. 
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bci string 



This pseudo-instruction generates a sequence of 6-bit character fields 
each of which contains the binary coded decimal (BCD) octal value for 
the corresponding graphic character in string . The last machine word 
generated is low-order filled with binary Os to the next word 
boundary. 



vfd field! , field2 , 



.fieldn 



This pseudo-instruction generates a machine word (or word-pair) 
containing an arbitrary number of fields of arbitrary length up to a 
total bit count of 72. The data generated is left-justified in the 
machine word (or word-pair) and zero filled to the next word boundary 
as necessary. 

Each fieldi is given as: 

md / expr 

where: m is the data conversion mode and may be: 

null for arithmetic operators and decimal literals, 

o for Boolean operators and octal literals, 

h for 6-bit character binary coded decimal (BCD) 

character strings, or 
a for 9-bit byte ASCII, character strings. 

d is a literal giving the field width in bits and may have 
any value from 1 to 72. 

expr is the expression to be evaluated or converted. 
Conversion is done with full 36-bit precision and the field 
value is the conversion result modulo the field width. 



COMPUTED ADDRESS FORMATION 



The address formation algorithms described here produce values only for the 
computed address. The effective segment number is constant and equal to 
C(PPR.PSR) if the processor is in append mode or is undefined if the processor 
is in absolute mode. 



The Address Modifier (TAG) Field 

Bits 30-35 of an instruction word or indirect word constitute the address 
modifier or TAG field. The format of the TAG field is: 



3 3 
1 


3 3 
2 5 


T 


T d 



Figure 6-1. Address- Modifier (TAG) Field Format 
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Field Name Function 

T m modifier field, specifies one of four general types of 
computed address modification 

T d designator field, selects among several variations available 
for the general type given with T„ 



General Types of Computed Address Modification 

There are four general types of computed address modification: register 
register then indirect, indirect then register, and indirect then tally. The 
general types are described in Table 6-1. The value loaded into TPR.CA is 
symbolized by "y" in the descriptions following. 
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Table 6-1 . General Computed Address Modification Types 



value 



Type 



Description 



Register (r) 



Register then 
indirect (ri) 



indirect then 
tally (it) 



indirect then 
register (ir) 



The contents of the register specified in C(T d ) are 
added to the current computed address, C(TPR.CA), 
to form the modified computed address. Addition is 
twos complement, modulo 2'°, and overflow does not 
occur. 

The contents of the register specified in C(T d ) are 
added to the current computed address, C(TPR.CA), to 
form the modified computed address as for register 
modification. The modified C(TPR.CA) is then used 
to fetch an indirect word. The TAG field of the 
indirect word specifies the next step in computed 
address formation. The use of du or dl as the 
designator in this modification type will cause 
an illegal procedure, illegal modifier, fault. 

The indirect word at C(TPR.CA) is fetched and the 
modification performed according to the variation 
specified in C(T d ) of the instruction word and the 
contents of the indirect word. This modification 
type allows automatic incrementing and decrementing 
of addresses and tally counting. 

The register designator, C(T d ), is safe-stored in a 
special holding register, CT-HOLD. The word at 
C(TPR.CA) is fetched and interpreted as an indirect 
word. The TAG field of the indirect word specifies 
the next step in computed address formation as 
follows: 

Indirect 

TAG Next step 

r or it Perform- register modification using T d from 
CT-HOLD. ri) 

Perform the register then indirect modifi- 
cation immediately and fetch the next 
indirect word from the result of that modi- 
fication. 

Replace the safe-stored T^ value in CT-HOLD 
with the T d value from the indirect word 
TAG field and use the ADDRESS field of the 
indirect word as a computed address value 
to fetch the next indirect word. 



ri 



ir 



(1) 



In this instance, the indirect then tally variations fault tag 1, fault tag 
2, and fault tag 3 are treated differently. The fault tag 1 variation 
results in the action described here but fault tag 2 and fault tag 3 result 
in the generation of a fault. See the discussion of indirect then tally 
modification later in this section. 



6-5 



AL39 



Computed Address Formation Flowcharts 

• ««4.i-IIl e ^ {i owcha . rt f depicting "the computed address formation process are 
scattered throughout this section and are linked together by figuYe references 
The flowcharts start with Figure 6-2. s reierences. 




m 



IT MOD 



M Q ir mod~) 



(Figure 6-3) (Figure 6-4) (Figure 6-5) (Figure 6-6) 
Figure 6-2. Common Computed Address Formation Flowchart 



Register (r) Modification 



In register modification (T = o) the value of T 



:S^l M &S sf "£ir SAi '» a !"."-«' * *~ .'t-«SSf "VA/ei^'SS 



modified C(TPR.CA) becomes the computed address of the operand 
Table 6-2, and the examples following. 



See Figure 6-3, 
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Q«») 



Yes / T.=0? 



> 



No 



(^£y 



Yes 



Mo 



r=T H 

^(TPR.CA) + C(r) -> 
C(TPR.CA) 



C 



Set direct operand flag 
Form operand 



END CA 



") 



Figure 6-3. Register Modification Flowchart 
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Table 6-2. Register Modification Decode 



T Coding 

value Register Symbol Computed Address 




1 

2 
3 

4 
5 
6 
7 

10 
11 
12 
13 
14 
15 
16 
17 



none 

A 0,17 

Q 0,17 
none 

PPR.IC 

A 18,35 

Q 18,35 
none 

X0 
X1 

X2 
X3 
X4 

X5 
X6 
X7 



n-, null 
au 
qu 
du 

ic 

al 

ql 
dl 

0, xO 

1 , x1 

2, x2 

3, x3 

4, x4 

5, x5 

6, x6 

7, x7 



y + C(A) 0j17 

y + c(Q) 0jl7 

none; y becomes the upper 18 bits of 
the 36-bit zero filled operand 

y + C(PPR.IC) 

y + C(A) 18>35 

y + C(Q) 18>35 

none; y becomes the lower 18 bits of 
the 36-bit zero filled operand 

y + C(X0) 

y + C(X1) 

y + C(X2) 

y + C(X3) 

y + C(X4) 

y + c(X5) 

y + C(X6) 

y +- C(X7) 



Examples: 



1. 

2. 

3. 
4. 
5. 



Location 


Instruction 


a 


Ida 


y 


a 


sta 


y,n 


a 


ldaq 


y,au 


a 


tra 


3,ic 


a 


ldq 


y,du 


a 


1x14 


y.di 


a 


rapy 


y.1 


a 


stx4 


y,7 



Computed address 

y 

y 

y + C(A) Qj17 

a + 3 

none; operand has the form 
y! i (00. . .0) 18 

none; operand has the form 
(00...0) 18| |y 

y + C(X1) 

y + C(X7) 
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Register Then Indirect (ri) Modifications 

In register then indirect modification (T _ .•> the value of T. designates 
a register whose contents are to be added to ~C(TPR. CA) to form a modified 
C(TPR.CA). This modified C(TPR.CA) is used as a computed address to fetch an 
indirect word. The ADDRESS field of the indirect word is loaded into TPR.CA and 
the TAG field of the indirect word is interpreted in the next step of an 
indirect chain. The TALLY field of the indirect word is ignored. 

The indirect chain continues until an indirect word TAG field specifies a 
modification without indirection. 

The coding symbol for register then indirect modification is r* where r is 
any of the coding symbols for register modification as given in Table 6-1 above 
except du and dl. The du and dl register codes are illegal and and their use 
causes an illegal procedure, illegal modifier, fault. See Figure 6-4, Table 
6-1, and the examples following. 



f RI MOD") 



il, 



No 



Yes 



f ABORT ") 



illegal procedure, 
illegal modifier, fault 



T d =0? 



Yes 



No 



Indirect word 
fetch APPEND 
CYCLE 
(Figure 5-4) 



Indirect word 
ADDRESS -> 
C(TPR.CA) 



c 



START CA 



J 



mPR.CA) + C(r) -> 
C(TPR.CA) 



(Figure 6-2) 



Figure 6-4. Register Then Indirect Modification Flowchart 
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Examples: 



Location 

a 
b 



b+C(X1) 

a 

a+H 

c 

a 

b+C(X0) 

c+C(X1) 



Instruction 



Ida 
arg 

ldq 
arg 

tra 
arg 
arg 



b,« 

y 

b,1* 
y,au 

4,ic« 



1x14 b,0* 
arg o,1* 
arg y,dl 



Computed address 
(r = null) 

y 



y + C(A) 0fl7 



none; operand has the form 
(O0...0) l8 i iy 



Indirect Then Register (ir) Modification 

In indirect then register modification (T_ = 3) the value of T H designates 
a register whose contents are to be added to C(TPR.CA) to form the final 
modified C(TPR.CA) during the last step in the indirect chain. The value of T H 
is held in a special holding register, CT-HOLD. The initial C(TPR.CA) is used 
an as computed address to fetch an indirect word. The ADDRESS of the indirect 
word is loaded into TPR.CA and the TAG field of the indirect word is interpreted 
in the next step of an indirect chain. The TALLY field of the indirect word is 
ignored. 

If the indirect word TAG field specifies a register then indirect 
modification, that modification is performed and the indirect chain continues. 

If the indirect word TAG field specifies indirect then register 
modification, the T d value from that TAG field replaces the T H value in CT-HOLD 
and the indirect chain continues. _ 

If the indirect word TAG specifies register or indirect then tally 
modification, that modification is replaced with a register modification using 
the T d value in CT-HOLD and the indirect chain ends. 



The coding symbol for indirect then register modification is *r where r is 
any of the coding symbols for register modification as given in Table 6-2 except 
"■■ 11 See Figure 6-5, Table 6-1, and the examples following. 



null. 
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f IR MOD") 



m 



r=T d 

C"(TPR.CA) + C(r) -> 

C(TPR.CA) 



T d -> CT-HOLD 



Indirect word 
fetch APPEND 
CYCLE 
(Figure 5-4) 



Indirect word 
ADDRESS -> 
C(TPR.CA) 



< Interpret 
indirect TAG 



Dl 



m 



ID 



No 



Fault tag 
2 or 3? 



-r=CT-HOLD 
TJ(TPR.CA) + C(r) -> 
C(TPR.CA) 



Yes 



f END CA ~) 



f ABORT ") 

Fault tag 2 
or 3 fault 



Figure 


6-5. Indirect 


Then Register Modification Flowch 


Examples: 






Location 


Instruction 


Computed address 


1. a 

b 


Ida b,*n 
arg y,2 


(CT-HOLD = n) 

y 


2. a 
b 


1x12 b,*dl 
sta y,au 


(CT-HOLD r dl) 
none; operand has the form 
(00...0) l8 iiy 
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a 


Ida 


b,»1 


b 


arg 


c,n* 


c 


arg 


d,*4 


d 


arg 


y.qi 


a 


ldxO 


b,1» 


b+C(X1) 


arg 


c,*i 


c 


arg 


5,dl 



(CT-HOLD = xl) 

(CT-HOLD = x4) 
y + C(X4) 



(CT-HOLD = ic) 
a + 5 



Indirect Then Tally (it) Modification 

In indirect then tally modification (T_ = 2) the value of T d * specifies a 
variation. The initial C(TPR.CA) is used an as computed address to fetch an 
indirect word. The indirect word is interpreted and possibly altered as the 
modification is performed. If the specified variation involves alteration of 
the indirect word, the indirect word is fetched with a special main memory cycle 
that prevents other processors from accessing it until the alteration is 
complete. 

The TALLY field of the indirect word is used to count references made to 
the indirect word. It has a maximum range of 4096.. If the TALLY field has the 
value after a reference to the indirect word, the tally runout indicator will 
be set ON, otherwise the tally runout indicator is set OFF. The value of the 
TALLY field and the state of the tally runout indicator have no effect on 
computed address formation. 

If there is more than one indirect word in an indirect chain that is 
referenced by a tally counting variation, only the state of the TALLY field of 
the last such word is reflected in the tally runout indicator. 

The variations of the indirect then tally modification are given in Table 
6-3 and explained in detail in the paragraphs following. Those entries given as 
"Undefined" cause an illegal procedure, illegal modifier, fault. See Figure 
6-6, Table 6-1, and the examples following. 
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Table 6-3- Variations of Indirect Then Tally Modification 



T d 

value 


Coding 
symbol 


Computed address 





f1 


Fault tag 1 


1 




Undefined (see itp modification later in this section) 


2 




Undefined 


3 




Undefined (see its modification later in this section) 


4 


sd 


Subtract delta 


5 


scr 


Sequence character reverse 


6 


f2 


Fault tag 2 


7 


f3 


Fault tag 3 


10 


ci 


Character indirect 


11 


i 


Indirect 


12 


sc 


Sequence character 


13 


ad 


Add delta 


14 


di 


Decrement address, increment tally 


15 


die 


Decrement address, increment tally, and continue 


16 


id 


Increment address, decrement tally 


17 


idc 


Increment address, decrement tally, and continue 



Fault tag 1 (T d = 0) 



If this variation appears in an indirect word and the TAG of the 
instruction word or preceding indirect word is indirect then register 
(ir), then terminate computed address formation with a register (r) 
modification using the register held in CT-HOLD. If this variation 
appears in an instruction word or in an indirect word and the TAG of 
the instruction word or preceding indirect word is not indirect then 
register (ir), then generate a fault tag 1 fault. 

C(TPR.CA) at the time of the fault contains the computed address of 
the word containing the fault tag 1 variation. Thus, the ADDRESS and 
TALLY fields of that word may contain information relative to recovery 
from the fault . 



Subtract delta (T d = 4) 



The TAG field of the indirect word is interpreted as a 6-bit, 
unsigned, positive address increment value, delta. For each reference 
to the indirect word, the, ADDRESS field is reduced by delta and the 
TALLY field is increased by 1 b efore the computed address is formed. 
ADDRESS arithmetic is modulo 2" tt \ TALLY arithmetic is modulo 4096. 
If the TALLY field overflows to 0, the tally runout indicator is set 
ON, otherwise it is set OFF. The computed address is the value of the 
decremented ADDRESS field of the indirect word. 
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Example: 



Location Instruction 

a Ida b,sd 

b vfd l8/c,12/t,6/d 



Reference 
count 

1 
2 
3 



Computed 
address 

c-d 

c-2d. 

c-3d 

c-nd 



Tally 
value 

t+1 
t+2 
t+3 

t+n 



Sequence character reverse (T d = 5) 

Bit 30 of the TAG field of the indirect word is interpreted as a 
character size flag, to, with the value indicating 6-bit characters 
and the value 1 indicating 9-bit bytes. Bits 33-35 of the TAG field 
are interpreted as a 3-bit character/byte position counter, cf. Bits 
31-32 of the TAG field must be zero. 

For each reference to the indirect word, the character counter, cf is 
reduced by 1 and the TALLY field is increased by 1 before the computed 
address is formed. Character count arithmetic is modulo 6 for 6-bit 
characters and modulo 4 for 9-bit bytes. If the character count, cf, 
underflows to -1, it is reset to 5 for 6-bit characters or to 3 for 
9-rbit bytes and ADDRESS is reduced by 1. ADDRESS arithmetic is modulo 
2 . TALLY arithmetic is modulo 4096. If the TALLY field overflows 
to 0, the tally runout indicator is set ON, otherwise it is set OFF. 
The computed address is the (possibly) decremented value of the 
ADDRESS field of the indirect word. The effective character/byte 
number is the decremented value of the character position count, cf. 
field of the indirect word. 

A 36-bit operand is formed by high-order zero filling the value of 
character cf-1 of C(computed address) with an appropriate number of 
bits. 

Examples: 



Location Instruction 



a 
b 
c 



Reference Computed Tally 
■count cf address value 



a 
b 
c 



Ida 
vfd 
bci 


b scr* 

18/C+1, 12/t, 1/0, 5/3 
"ABCDEFGHIJKL" 


1 
2 
3 
4 

5 

• • • 


2 

1 

5 
4 


c+1 
c+1 
c+1 

c 

c 


t+1 (00. 
t+2 (00. 
t+3 (00. 
t+4 (00. 
t+5 (00. 


Ida 
vfd 
aci 


b,scr 

18/c+l , 12/t, 1/1 ,5/3 
"abcdefgh" 


1 
2 
3 
4 
5 


2 
1 


3 
2 


c+1 

c+1 
c+1 

c 

c 


t+1 (00. 
t+2 (00. 
t+3 (00. 
t+4 (00. 
t+5 (00. 



Operand 



.0) 
.0) 
.0) 
.0) 
.0) 



30 
30 
30 
30 
30 



.0) 
.0) 
.0) 
.0) 
.0) 



21 
27 
27 

27 
27 



'I" 



i .. F it 
I "E" 



! "g" 
! "f " 
e" 



! »« 



Fault tag 2 (T d = 6) 



Terminate computed address formation immediately and generate a fault 
tag 2 fault. 

C(TPR.CA) at the time of the fault contains the computed address of 
the word containing the fault tag 2 variation. Thus, the ADDRESS and 
TALLY fields of that word may contain information relative to recovery 
from the fault. 
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Fault tag 3 (T H = 7) 



Terminate computed address formation immediately and generate a fault 
tag 3 fault. 

C(TPR.CA) at the time of the fault contains the computed address of 
the word containing the fault tag 3 variation. Thus, the ADDRESS and 
TALLY fields of that word may contain information relative to recovery 
from the fault. 



Character indirect (T d = 10) 



Bit 30 of the TAG field of the indirect word is interpreted as a 
character size flag, tb, with the value indicating 6-bit characters 
and the value 1 indicating 9-bit bytes. Bits 33-35 of the TAG field 
are interpreted as a 3-bit character/byte position value, cf. Bits 
31-32 of the TAG field must be zero. 

If the character position value is greater than 5 for 6-bit characters 
or greater than 3 for 9-bit bytes, an illegal procedure, illegal 
modifier, fault will occur. The TALLY field is ignored. The computed 
address is the value of the ADDRESS field of the indirect word. The 
effective character/byte number is the value of the character position 
count, cf, field of the indirect word. 

A 36-bit operand is formed by high-order zero filling the value of 
character cf of CCcomputed address) with an appropriate number of 
bits. 

Examples: 

Location Instruction Operand 

a Ida b,ci 

b vfd 18/0+1,12/0,1/0,5/2 (00. . .0), n | j"I" 

c bci "ABCDEFGHIJKL" J 

a Ida d,ci 

d vfd 18/0,12/0,1/0,5/1 (00. . .0) 30 i !"B" 

a Ida e,ci 

e vfd 18/f, 12/0, 1/1, 5/3 (00. . .0) ?7 j I "d" 

f aci "abcdefgh" ' 

a Ida g,ci 

g vfd 18/f+l, 12/0, 1/1, 5/0 C00...0) 27 l!"e" 



Indirect (T ri = 11) 



The computed address is the value of the ADDRESS field of the indirect 
word. The TALLY and TAG fields of the indirect word are ignored. 



Sequence character (T^ = 12) 



Bit 30 of the TAG field of the indirect word is interpreted as a 
character size flag, tb, with the value indicating 6-bit characters 
and the value 1 indicating 9-bit bytes. Bits 33-35 of the TAG field 
are interpreted as a 3-bit character position counter, cf. Bits 31-32 
of the TAG field must be zero. 

For each reference to the indirect word, the character counter, cf, is 
increased by 1 and the TALLY field is reduced by 1 after the computed 
address is formed. Character count arithmetic is modulo 6 for 6-bit 
characters and modulo 4 for 9-bit bytes. If the character count, cf, 
overflows to 6 for 6-bit characters or to 4 for 9-bit bytes, it is 
reset to and ADDRESS is increased by 1. ADDRESS arithmetic is 
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modulo 2 18 . TALLY arithmetic is modulo 4096. If the TALLY field is 
«2 U nFP Th' thS * al „ ly ^ unout indica tor is set ON, otherwise it is 
fuif tu « co "?- uted address is the unmodified value of the ADDRESS 
iieid. The effective character/byte number is the unmodified value of 
the character position counter, cf, field of the indirect word. 

L^lH+L °P* ra " d i, s formed by high-order zero filling the value of 
character cf of C(computed address) with an appropriate number of 

Examples: 



Location Instruction 



a 
b 
c 



a 
b 
c 



Reference Computed Tally 
count cf address value 



Ida 
vfd 
bci 


b,sc 

18/c,12/t, 1/0,5/4 
"ABCDEFGHIJKL" 


1 
2 

3 


4 
5 



c 

c 

c+1 


t-1 (00. 
t-2 (00. 
t-3 (00. 






4 


1 


c+1 


t-4 (00. 






5 

• • « 


2 


c+1 


t-5 (00. 


Ida 
vfd 
aci 


b,sc 

18/c,12/t,1/1,5/2 
"abcdefgh" 


1 
2 
3 


2 
3 



c 

c 

c+1 


t-1 (00. 
t-2 (00. 
t-3 (00. 






4 


1 


c+1 


t-4 (00. 






5 


2 


c+1 


t-5 (00. 



Operand 

• - > 30 1 

• • 0) 3Q ! 

• '°>30j 
. •0)301 



II £11 
liptl 
IIQI1 

"H" 

11 j 11 



.0) 27 | !"c» 
.0)37! ! "d» 
.0);ij S»e" 
0)2 7 ii"f" 
■0)||| |»g» 



Add delta (T d = 13) 



The TAG field of the indirect word is interpreted as a 6-bit 
unsigned, positive address increment value, delta. For each reference 
t?, , £ e * x . nd , i J re ? t word ' the ADDR£ SS field is increased by delta and the 
InnnLo , J- S reduced b y 1 ^ ter the computed address is formed. 
tp X SS .r?r ri v h ;? tiC iS m0dul ° 2^T- TALLY arithmetic is modulo 4096. 
™ fu F leld is reduced to 0. the tally runout indicator is set 
ON, otherwise it is set OFF. The computed address is the value of the 
unmodified ADDRESS field of the indirect word. 

Example: 



Location Instruction 

a Ida b,ad 

b vfd 18/c,1/t,6/d 



Reference 
count 

1 
2 
3 



Computed Tally 
address value 



c 
c+d 
c+2d 

c+(n-1)d 



t-1 
t-2 
t-3 

t-n 



Decrement address, increment tally (T d = 14) 

For each reference to the indirect word, the ADDRESS field is reduced 
by 1 and the TALLY field is increased by 1 before the computed address 
is formed. ADDRESS arithmetic is modulo 2 Ta . TALLY arithmetic is 
modulo 4096. If the TALLY field overflows to 0, the tally runout 
indicator is set ON, otherwise it is set OFF. The TAG field of the 
indirect word is ignored. The computed address is the value of the 
decremented ADDRESS field. 
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Example: 



Location Instruction 

a Ida b,di 

b vfd l8/c,12/t 



Reference 
count 

1 
2 
3 



Computed 
address 

c-1 
c-2 
c-3 

c-n 



Tally 
value 

t+1 

t+2 
t+3 

t+n 



Decrement address, increment tally, and continue (T d = 15) 

The action for this variation is identical to that for the decrement 
address, increment tally variation except that the TAG field of the 
indirect word is interpreted and continuation of the indirect chain is 
possible. If the TAG of the indirect word invokes a register, that 
is, specifies r, ri , or ir modification, the effective T d value for 
the register is forced to "null" before the next computed address is 
formed. 

Increment address, decrement tally (T d = 16) 

For each reference to the indirect word, the ADDRESS field is 
increased by 1 and the TALLY field is reduced by 1 after the computed 
address is formed. ADDRESS arithmetic is modulo 2 18 . TALLY 
arithmetic is modulo H096. If the TALLY field is reduced to 0, the 
tally runout indicator is set ON, otherwise it. is set OFF. The TAG 
field of the indirect word is ignored. The computed address is the 
value of the unmodified ADDRESS field. 

Example: 



Location Instruction 

a Ida b,id 

b vfd !8/c,1/t 



Reference 
count 

1 
2 



* • t 

n 



Computed 
address 

c 
c+1 
c+2 

c+(n-1) 



Tally 
value 

t-1 
t-2 
t-3 

t-n 



Increment -address, decrement tally, and continue (T d = 17) 

The action for this variation is identical to that for the increment 
address, decrement tally variation except that the TAG field of the 
indirect word is interpreted and continuation of the indirect chain is 
possible. If the TAG of the indirect word invokes a register, that 
is, specifies r, ri, or ir modification, the effective T d value for 
the register is forced to "null" before the next computed address is 
formed . 
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( IT MOD") 



Interpret 
T^ 



C 



T d =0,6,7 
(T1,f2, 
f3) 



ABORT 



D 



T d »1,2,3 
(ufidef) 



Fault tag 1, 
2, or 3 fault 



T =10,12,5 
(el ,sc,scr) 



Indirect word 
fetch APPEND 
CYCLE 
(Figure 5-4) 



is the 
No / cf value 
legal? 



f ABORT } 

Illegal procedure, 
illegal modifier, 
fault 



Yes 



cf field, and 
ADDRESS. Form 
computed 
address 



T d = l1 , 13,4, 14, 16 

(i,ad,sd,di,id) 



Indirect word 
fetch APPEND 
CYCLE 
(Figure 5-4) 



m 



G^ED 



T d =15,17 
(dxc,idc) 



Indirect word 
fetch APPEND 
CYCLE 
(Figure 5-4.) 



Adjust TALLY 
and form 
computed 
address 



Interpret 
indirect TAG 



T =ir or it 
m 



m 



Indirect word 
fetch APPEND 
CYCLE 
(Figure 5-4) 



i — - 

f START CA ~\ 
(Figure 6-2) 



Figure 6-6. Indirect Then Tally Modification Flowchart 
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VIRTUAL ADDRESS FORMATION INVOLVING BOTH SEGMENT NUMBER AND COMPUTED ADDRESS 

The second type of virtual address formation generates an effective segment 
number and a computed address simultaneously. 

The Use of Bit 29 in the Instruction Word 



The reader is reminded that there is a preliminary step of loading TPR.CA 
with the ADDRESS field of the instruction word during instruction decode. 

If bit 29 of the instruction word is set to 1, modification by pointer 
register is invoked and the preliminary step is executed as follows: 

1. The ADDRESS field of the instruction word is interpreted as shown in 
Figure 6-7 below. 

2. C(PRn.SNR) -> C(TPR.TSR) 

3. maximum of (c(PRn.RNR), C(TPR.TRR), C(PPR.PRR)) -> C(TPR.TRR) 
H. C(PRn.WORDNO) + OFFSET -> C(TPR.CA) 

(NOTE: OFFSET is a signed binary number.) 
5. C(PRn.BITNO) -> TPR.BITNO 



ft. 




_2 



PRn 



i. 



OFFSET 



15 



Figure 6-7. Format of Instruction Word ADDRESS When Bit 29 = 1 



After this preliminary step is performed, virtual address formation proceeds 
as discussed above or as discussed for the special address modifiers below. 



Special Address Modifiers 

Whenever the processor is forming a virtual address two special address 
modifiers may be specified and are effective under certain restrictive conditions. 
The special address modifiers are shown in Table 6-4 and discussed in the paragraphs 
below. 

The conditions for which the special address modifiers are effective are as 
follows: 

1. The instruction word (or preceding indirect word) must specify indirect 
then register or register then indirect modification. 

2. The computed address for the indirect word must be even. 

If these conditions are satisfied, the processor examines the indirect word 
TAG field for the special address modifiers. 



:i/82 
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If either condition is violated, the indirect word TAG field is interpreted 
as a normal address modifier and the presence of a special address modifier will 
cause an illegal procedure, illegal modifier, fault. 



Table 6-4. Special Address Modifiers 



TAG Coding 
Value Symbol Name 



41 
43 



ITP 
ITS 



Indirect to pointer 
Indirect to segment 



| Indirect to Pointer (ITP) Modification 

If the value for indirect to pointer modification is found in the test for 
I special modifiers, the indirect word-pair is interpreted as an ITP pointer pair 
(see Figure 6-8 for format) and the following actions take place: 

For n = C(ITP.PRNUM) : 

C(PRn.SNR) -> C(TPR.TSR) 

maximum of (c(PRn.RNR), C(SDW.R1), C(TPR.TRR)} -> C(TPR.TRR) 

C(ITP.BITNO) -> C(TPR.TBR) 

C(PRn.WORDNO) + C(ITP. WORDNO) + C(r) -> C(TPR.CA) 

where: 

1. r = C(CT-HOLD) if the instruction word or preceding indirect word 
specified indirect then register modification, or 

2. r = C(ITP.MOD.T d ) if the instruction word or preceding indirect 
word specified register then indirect modification and ITP. MOD. T_ 
specifies either register or register then indirect modification. 

3- SDW.R1 is the upper limit of the read/write ring bracket for the 
segment C(PRn.SNR) (see Section 8). 
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Even Word 

2 1 












2 
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■5 


PRNUM 


0000000000000 
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418 


3 






27 
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Odd word 
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BITN0 








MQD 


*■ 


T d 




t8 


3 6 


3 


2 




Jt 


Figure 6-8. 


ITP Pointer Pair Format 












Field 

Name Meaning 























PRNUM The number of the pointer register through which to make the 
segment reference 

W0RDN0 A word offset value to be added to C(PRn.WORDNO) 

BITNO A bit offset value for the data item 

MOD Any normal address modifier ( not ITP or ITS) 



Indirect to Segment (ITS) Modification | 

If the value for indirect to segment modification is found in the test for 
special modifiers, the indirect word-pair is interpreted as an ITS pointer pair | 
(see Figure 6-9 for format) and the following actions take place: 

CUTS. SEGNO) -> C(TPR.TSR) 

maximum of (c(ITS.RN), C(SDW.R1), C(TPR.TRR)) -> C(TPR.TRR) 

C(ITS. BITNO) -> C(TPR.TBR) 

C(ITS.WORDNC) + C(r) -> C(TPR.CA) 

where: 

1. r = C(CT-HOLD) if the instruction word or preceding indirect word 
specified indirect then register modification, or 

2. r = C(ITS.M0D.T d ) if the instruction word or preceding indirect 
word specified register then indirect modification and ITS. MOD. T m 
specifies either register or register then indirect modification. 

3. SDW.R1 is the upper limit of the read/write ring bracket for the 
segment C( ITS. SEGNO) (see Section 8). 
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Even Word 

2 3 







SEGNO 



1 1 
78 



2 2 



RN 



15 



2 3 



000000000 



*3 8 



3 

1 



Odd word 







I 2 




1 
7 


1 2 
8 


2 
1 




2 


2 2 
7 9 


3 3 3 

g i 2 _ 


3 
-5, 


WORDNO 





BITN0 





MOD 


T 


T d 








18 


3 






6 


3 


2 




4 



Figure 6-9. ITS Pointer Pair Format 



Field 
Name 

SEGNO 

WORDNO 

BITN0 

HOD 



Meaning 

The number of the segment to be referenced 

Word offset to be used in the computed address formation 

The bit offset for the data item 

Any valid normal address modifier ( not ITS or ITP) 



Effective Segment Number Generation 

A simplified flowchart for effective segment number generation is given in 
Figure 6-10. Although effective ring number generation and access checking are 
an integral part of this process, their treatment is deferred to Section 8. 
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Figure 6-10. Effective Segment Generation Flowchart 
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JSL/ TAG = \Yes 
ITS? 
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No 



<Need an \ 
indirect / 
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n = C(Y) 2 
C(PRn.SNR) -> 
C(TPR.TSR) 
C(PRn.WORDNO) + 
C(Y+T) 17 -> 
C(TPR.CA) 
C(ITP.MOD) -> TAG 



Isa. 



I 



C(Y),> 17 -> 

c(tpr:tsr) 

C(Y+1) 17 -> 
C(TPR.CA) 
C(ITS.MOD) -> TAG 




C 



START ESN 



5 



(Figure 6-10) 
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C(TPR.CA) -> 
C(PPR.IC) 
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1 



< appending X 

unit data J 

»Bi°Y e nsnt? / 

No 



lu 



I 



(" EXECUTE } 
(Not shown) 



I 



f END ESN~) 

Figure 6-10(cont). Effective Segment Number Generation Flowchart 



VIRTUAL ADDRESS FORMATION FOR EXTENDED INSTRUCTION SET 

The steps involved in virtual address formation for the operand of an EIS 
instruction are shown in Figure 6-11. The flowchart depicts the virtual address 
formation for operand k as described by its modification field, MFk. This virtual 
address formation is performed for each operand as its operand descriptor is 
decoded. 
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nsnull 



r=null 



Yes 




ESN CYCLE 
(Figure 6-10) 



I 
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APPEND CYCLE 
(Figure 5-4) 
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I 



Form effective 
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Y f CN f C | Bf 
C(PRn), C(r) 

<N9TE hV 



c 



t 



END EIS CA 



D 



Figure 6-11. EIS Virtual Address Formation Flowchart 



NOTE 1: The symbol "Y" stands for the contents of the ADDRESS field of the 
operand descriptor. The symbols "CN" and "C" stand for the contents 
of the character number field. The symbol "B" stands for the contents 
of the bit number field. 

NOTE 2: The algorithms used in the formation of the effective word/char/bit 
address are described below. 
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Character- and Bit-String Addressing 

The processor represents the effective address of a character- or 
bit-string operand in three different forms as follows: 

1. Pointer register form 

This form consists of a word value (PRn.WORDNO) and a bit value 
(PRn.BITNO). The word value is the word offset of the word containing 
the first character or bit of the operand and the bit value is the bit 
position of that character or bit within the word. This form is seen 
when C(PRn) are stored as an its pointer pair or as a packed pointer 
(see discussion of its pointers earlier in this section and the Store 
Pointer Register n Packed (sprpn) instruction in Section 4). 

2. Address register form 

This form consists of a word value (ARn.WORDNO) , a byte number 
(ARn.CHAR), and a bit value (ARn.BITNO). The word value is the word 
offset of the word containing - the first character or bit of the 
operand. The byte number is the number of the 9-bit byte containing 
the first character or bit. The bit value is the bit position within 
ARn.CHAR of the first character or bit. This form is seen when C(ARn) 
are stored with the Store Address Register n (sarn) instruction (see 
Section 4). ~ ~ 

3. Operand Descriptor Form 

This form is valid for character-string operands only. It consists of 
a word value (ADDRESS) and a character number (CN). The word value is 
the word offset of the word containing the first character of the 
operand and the character number is the number of that character 
within the word. This form is seen when C(ARn) are stored with the 
Address Register n to Alphanumeric Descriptor (aran) or Address 
Register n to Numeric Descriptor (arnn) instructions. (The operand 
descriptor form for bit-string operands is identical to the address 
register form.) 

The terms "pointer register" and "address register" both apply to the same 
physical hardware. The distinction arises from the manner in which the register 
is used and in the interpretation of the register contents. "Pointer register" 
refers to the register as used by the appending unit and "address register" 
refers to the register as used by the decimal unit. 

The three forms are compatible and may be freely intermixed. For example, 
PRn may be loaded in pointer register form with the Effective Pointer to Pointer 
Register n (eppn) instruction, then modified in pointer register form with the 
Effective Address to Word/Bit Number of Pointer Register n (eawpn) instruction, 
then further modified in address register form (assuming character size k) with 
the Add k-Bit Displacement to Address Register (akbd) instruction, and finally 
invoked in operand descriptor form by the use of MF.AR in an EIS multiword 
instruction. 



Character- and Bit-String Address Arithmetic Algorithms 

The arithmetic algorithms for calculating character- and bit-string 
addresses are presented .below. The symbols "ADDRESS" and "CN" represent the 
ADDRESS and CN fields of the operand descriptor being decoded, "r" and "n" are 
set according to the flowchart in Figure 6-11. If either has the value "null", 
the contents of all associated fields are identically zero. 
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9-BIT BYTE STRING ADDRESS ARITHMETIC 



Effective BITNO 
Effective CHAR 
Effective WORDNO 



= OOOO 

= (CM + CCARn. CHAR) + C(r))M 

= ADDRESS + CCARn. WORDNO) + 

(CN + CCARn. CHAR) ♦ C(r)) / 4 



6-BIT CHARACTER STRING ADDRESS ARITHMETIC 



Effective BITNO 
Effective CHAR 
Effective WORDNO 



= (9*C(ARn.CHAR) + 6»CCr) + C(ARn.BITNO)) [gl 

= ((9»C(ARn.CHAR) + 6*C(r) «■ C(ARn.BITNO))[" 36 l ) / 9 

= ADDRESS + CCARn. WORDNO) + 

(9*C(ARn.CHAR) + 6*C(r) + C(ARn. BITNO) ) / 36 



4-BIT BYTE STRING ADDRESS ARITHMETIC 



Effective BITNO 
Effective CHAR 
Effective WORDNO 



= 4 • (C(ARn.CHAR) + 2»C(r) ♦ C (ARn. BITNO ) /4 ) Tg"] + 1 

= ((9*C(ARn.CHAR) + 4*C(r) + CCARn.BITNO))r 36 "l / 9 

= ADDRESS ♦ C(ARn. WORDNO) + 

(9*C(ARn.CHlR) + 4«C(r) + C(ARn. BITNO) ) / 36 



BIT STRING ADDRESS ARITHMETIC 



Effective BITNO 
Effective CHAR 
Effective WORDNO 



= (9*C(ARn.CHAR) + 36*C(r) ♦ C(ARn.BITNO)) Igl 

s <(9*C(ARn.CHAR) ♦ 36«C(r) ♦ C(ARn.BITNO)) p 36 "l) / 9 

= ADDRESS ♦ C(ARn. WORDNO) ♦ 

(9*C(ARn.CHlR) + 36*C(r) + CCARn. BITNO)) / 36 
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SECTION 7 
FAULTS AMD INTERRUPTS 



Faults and interrupts both result in an interruption of normal 
sequential processing, but there is a difference in how they originate. 
Generally, faults are caused by events or conditions that are internal to the 
processor and interrupts are caused by events or conditions that are external to 
the processor. Faults and interrupts enable the processor to respond promptly 
when conditions occur that require system attention. 

A unique word-pair is dedicated for the instructions to service each fault 
and interrupt condition. The instruction pair associated with a fault or 
interrupt is called the trap pair for that fault or interrupt. The set of all 
interrupt trap pairs is called the interrupt vector and is located at absolute 
main memory address 0. The set of all fault trap pairs is called the fault 
vector and is located at a modulo 32 absolute main memory address whose 
high-order bits are given by the setting of the FAULT BASE switches on the 
processor configuration panel. The fault vector is constrained to lie within 
the lowest 4096 words of main memory. 



FAULT CYCLE SEQUENCE 

Following the detection of a fault condition, the control unit determines 
the proper time to initiate the fault sequence according to the fault group 
(Fault groups are discussed later in this section). At that time, the control 
unit interrupts normal sequential processing with an ABORT CYCLE. The ABORT 
CYCLE brings all overlapped and asynchronous functions within the processor to 
an orderly halt. At the end of the ABORT CYCLE, the control unit initiates a 
FAULT CYCLE. 

In the FAULT CYCLE, the processor safe-stores the Control Unit Data (see 
Section 3) into program-invisible holding registers in preparation for a Store 
Control Unit (scu) instruction, then enters temporary absolute mode, forces the 
current ring of execution C(PPR.PRR) to 0, and generates a computed address for 
the fault trap pair by concatenating the setting of the FAULT BASE switches on 
the processor configuration panel with twice the fault number (see Table 7-1 )• 
This computed address and the operation code for the Execute Double (xed) 
instruction are forced into the instruction register and executed as an 
instruction. Note that the execution of the instruction is not done in a normal 
EXECUTE CYCLE but in the FAULT CYCLE with the processor in temporary absolute 
mode . 

If the attempt to fetch and execute the instruction pair at the fault trap 
pair results in another fault, the current FAULT CYCLE is aborted and a new 
FAULT CYCLE for the trouble fault (fault number 3D is initiated. In the FAULT 
CYCLE for a trouble fault, the processor does not safe-store the Control Unit 
Data. Therefore, it may be possible to recover the conditions for the original 
fault (except the fault number) by use of the Store Control Unit (scu) 
instruction. The fault number may usually be recovered by analysis of the 
computed address for the original fault trap pair stored in the control unit 
history registers. 
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If either of the two instructions in the fault trap pair results in a 
transfer of control to a computed address generated in absolute mode, the 
absolute mode indicator is set ON for the transfer and remains ON thereafter 
until changed by program action. 

If either of the two instructions in the fault trap pair results in a 
transfer of control to a computed address generated in append mode (through the 
use of bit 29 of the instruction word or by use of the its or itp modifiers), 
the transfer is made in the append mode and the processor remains in append mode 
thereafter. 

If no transfer of control takes place, the processor returns to the mode in 
effect at the time of the fault and resumes normal sequential execution with the 
instruction following the faulting instruction (C(PPR.IC) +1). Note that the 
current ring of execution C(PPR.PRR) was forced to during the FAULT CYCLE and 
that normal sequential execution will resume in ring 0. 

Many of the fault conditions are deliberately or inadvertently caused by 
the software and do not necessarily involve error conditions. The operating 
supervisor determines the proper action for each fault condition by analyzing 
the detailed state of the processor at the time of the fault. In order to 
accomplish this analysis, it is necessary that the first instruction in each of 
the fault trap pairs be the Store Control Unit (scu) instruction and the second 
be a transfer to a fault analysis routine. If a fault condition is to be 
intentionally ignored, the fault trap pair for that condition should contain an 
seu/rcu pair referencing a unique Y-block8. By using this pair to ignore a 
fault, the state of the processor for the ignored fault condition may be 
recovered if the ignored fault causes a trouble fault. The use of the scu/rcu 
pair also ensures that execution is resumed in the original ring of execution. 
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Table 7-1. List of Faults 



Decimal 


Octal* 1 - 


) 








fault 


fault 


Fault 








number 


address 


mnemonic 


Fault name 


Priority 


Group 








sdf 


Shutdown 


27 


7 


1 


2 


str 


Store 


10 


4 


2 


4 


mme 


Master mode entry 1 


11 


5 


3 


6 


f1 


Fault tag 1 


17 


5 


4 


10 


tro 


Timer runout 


26 


7 


5 


12 


cmd 


Command 


9 


4 


6 


14 


drl 


Derail 


15 


5 


7 


16 


luf 


Lockup 


5 


4 


8 


20 


con 


Connect 


25 


7 


9 


22 


par 


Parity 


8 


4 


10 


24 


ipr 


Illegal procedure 


16 


5 


11 


26 


one 


Operation not complete 


4 


2 


12 


30 


suf 


Startup 


1 


1 


13 


32 


ofl 


Overflow 


7 


3 


14 


34 


div 


Divide check 


6 


3 


15 


36 


exf 


Execute 


2 


1 


16 


40 


dfO 


Directed fault 


20 


6 


17 


42 


df1 


Directed fault 1 


21 


6 


18 


44 


df2 


Directed fault 2 


22 


6 


19 


46 


df3 


Directed fault 3 


23 


6 


20 


50 


acv 


Access violation 


24 


6 


21 


52 


mme 2 


Haster mode entry 2 


12 


5 


22 


54 


mme 3 


Master mode entry 3 


13 


5 


23 


56 


mme4 


Master mode entry 4 


14 


5 


24 


60 


f2 


Fault tag 2 


18 


5 


25 


62 


f3 


Fault tag 3 


19 


5 


26 


64 




Unassigned 






27 


66 




Unas signed 






28 


70 




Unassigned 






29 


72 




Unassigned 






30 


74 




Unassigned 






31 


76 


trb 


Trouble 


3 


2 



(1) The octal fault address value is the value concatenated with the FAULT BASE 
switch setting in forming the computed address for the fault trap pair. 



FAULT PRIORITY 



The processor has provision for 32 faults of which 27 are implemented- The 
faults are classified into seven fault priority groups that roughly correspond 
to the severity of the faults. Fault priority groups are defined so that fault 
recognition precedence may be established when two or more faults exist 
concurrently. Overlapped and asynchronous functions in the processor allow the 
simultaneous occurrence of faults. Group 1 has the highest priority and group 7 
has the lowest. In groups 1 through 6, only one fault within each group is 
allowed to be active at any one time. The first fault within a group occurring 
through the normal program sequence is the one serviced. 

Group 7 faults are saved by the hardware for eventual recognition. In the 
case of simultaneous faults within group 7, shutdown has the highest priority 
with timer runout next and connect the lowest. 
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There is a single exception to t handling of faults in priority group 

?- «; F a " °£ ei : and fetch generates a parity fault and the use of the operand 

£ , 2 ?J? ° U u instruction execution generates an overflow fault or a divide 

cneck fault, these faults are considered simultaneous but the parity fault takes 

precedence. 



FAULT RECOGNITION 

For the discussion following, the term "function" is defined as a major 
ll%nt S Vt r nt i Un ~ll~ nal cvcle - Examples are: APPEND CYCLE, CA CYCLE, INSTRUCTION 
FETCH CYCLE, OPERAND STORE CYCLE, DIVIDE EXECUTION CYCLE. Some of these cycles 
are discussed in various sections of this manual. 

Faults in groups 1 and 2 cause the processor to abort all functions 
immediately by entering a FAULT CYCLE. 

•„v Fau i fc f , in Sroup 3 cause the processor to "close out" current functions 
without taking any irrevocable action (such as setting PTW.U in an APPEND CYCLE 
or modifying an indirect word in a CA CYCLE), then to discard any pending 

FAULT CYCLE " '" APPEHD "^ "^^ dUrlng ' C * CYCLE) ' and to * nter » 

Faults in group 4 cause the processor to suspend overlapped operation, to 
complete current and pending functions for the current instruction, and then to 
enter a FAULT CYCLE. 

Faults in groups 5 or 6 are normally detected during virtual address 
formation and instruction decode. These faults cause the processor to suspend 
overlapped operation, to complete the current and pending instructions, and to 
enter a FAULT CYCLE. If a fault in a higher priority group is generated by the 
execution of the current or pending instructions, that higher priority fault 
will take precedence and the group 5 or 6 fault will be lost. If a group 5 or 6 
fault is detected during execution of the current instruction (e.g., an access 
violation, out of segment bounds, fault during certain interruptable EIS 
instructions) , the instruction is considered "complete" upon detection of the 
fault. 

Faults in group 7 are held and processed (with interrupts) at the 
completion of the current instruction pair. Group 7 faults are inhibitable bv 
setting bit 28 of the instruction word. 

Faults in groups 3 through 6 must wait for the system controller to 
acknowledge the last access request before entering the FAULT CYCLE. 



FAULT DESCRIPTIONS 

Group 1 Faults 

Startup 

DC POWER has been turned on. When the POWER ON button is pressed, the 
processor is first initialized and then the startup fault is 
generated. 
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Execute 



1. The EXECUTE pushbutton on the processor maintenance panel has 
been pressed. 

2. An external gate signal has been substituted for the EXECUTE 
pushbutton. 

The selection between the above conditions is made by settings of 
various switches on the processor maintenance panel. 



Group 2 Faults 



Operation Not Complete 



Trouble 



Any of the following will cause an operation not complete fault: 

1 . The processor has addressed a system controller to which it is 
not attached, that is, there is no main memory interface port 
having its ADDRESS ASSIGNMENT switches set to a value including 
the main memory address desired. 

2. The addressed system controller has failed to acknowledge, the 
processor. 

3. The processor has not generated a main memory access request or a 
direct operand within 1 to 2 milliseconds and is not executing 
the Delay Until Interrupt Signal (dis) instruction. 

4. A main memory interface port received a data strobe without a 
preceding acknowledgement from the system controller that it had 
received the access request. 

5. A main memory interface port received a data strobe before the 
data previously sent to it was unloaded. 



The trouble fault is defined as the occurrence of a fault during the 
fetch or execution of a fault trap pair or interrupt trap pair. Such 
faults may be hardware generated (for example, operation not complete 
or parity), or operating system generated (e.g., the page containing a 
trap pair instruction operand is missing)-. 



Group 3 Faults 



Overflow 



An arithmetic overflow, exponent overflow, exponent underflow, or EIS 
truncation fault has been generated. The generation of this fault is 
inhibited when the overflow mask indicator is ON. Resetting of the 
overflow mask indicator to OFF does not generate a fault from 
previously set indicators. The overflow mask state does not affect 
the setting, testing or storing of indicators. The determination of 
the specific overflow condition is by indicator testing by the 
operating supervisor. 
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Divide Check 



A divide check fault occurs when the actual division cannot be carried 
instructions" 6 ° f "** reason3 3 P ecif i«d with individual divide 



Group 4 Faults 



Store 



Command 



The processor attempted to select a disabled port, an out-of-bounds 
address was generated in the BAR mode or absolute mode, or an attempt 
was made to access a store unit that was not ready. 



1. 

2. 

3- 
4. 

5. 



The processor attempted to load or read the interrupt mask 
register in a system controller in which it did not have an 
interrupt mask assigned. 

The processor issued an XEC system controller command to a system 
controller in which it did not have an interrupt mask assigned. 

The processor issued a connect to a system controller port that 
is masked OFF. 



The selected system controller is in TEST mode and a condition 
determined by certain system controller maintenance 
switches has been trapped. 



panel 



An attempt was made to load a pointer register with packed 
pointer data in which the BITMO field value was greater than or 
equal to 60(g). 



Lockup 



Parity 



The program is in a code sequence which has inhibited sampling for 
interrupts (whether present or not) and group 7 faults for longer than 
the prescribed time. In absolute mode or privileged mode the lockup 
time is 32 milliseconds. In normal mode or BAR mode the lockup time 
is specified by the setting for the lockup time in the cache mode 
register. The lockup time is program settable to 2, 4. A. or 16 
milliseconds. 

While in absolute mode or privileged mode the lockup fault is 
signalled at the end of the time limit set in the lockup timer but is 
not recognized until the 32 millisecond limit. If the processor 
returns to normal mode or BAR mode after the fault has been signalled 
but before the 32 millisecond limit, the fault is recognized before 
any instruction in the new mode is executed. 



The selected system controller has returned an illegal action 
signal with an illegal action code for one of the various main 
memory parity error conditions. 

A cache memory data or directory parity error has occurred either 
for read, write, or block load. Cache status bits for the 
condition have been set in the cache mode register. 
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The processor has detected a parity error in the system 
controller interface port while either generating outgoing parity 
or verifying incoming parity. 



Group 5 Faults 

Master Mode Entries 1-4 

The corresponding Master Mode Entry instruction has been decoded. 

Fault Tags 1-3 

The corresponding indirect then tally variation has been detected 
during virtual address formation. 

Derail 

The Derail instruction has been decoded. 

Illegal Procedure 

1. An illegal operation code has been decoded or an illegal 
instruction sequence has been encountered. 

2. An illegal modifier or modifier sequence has been encountered 
during virtual address formation. 

3. An illegal address has been given in an instruction for which the 
ADDRESS field is used for register selection. 

4. An attempt was made to execute a privileged instruction in normal 
mode or BAR mode. 

5. An illegal digit was encountered in a decimal numeric operand. 

6. An illegal specification was found in an EIS operand descriptor. 

The conditions for the fault will be set in the fault register, word 1 
of the Control Unit Data, or in both. 



Group 6 Faults 

Directed Faults 0-3 

A faulted segment descriptor word (SDW) or page table word (PTV) with 
the corresponding directed fault number has been fetched by the 
appending unit. 

Access Violation 

The appending unit has detected one of the several access violations 
below. Word 1 of the Control Unit Data contains status bits for the 
condition. 

1. Not in read bracket (ACV3=0RB) 

2. Not in write bracket (ACV5=0WB) 

3. Not in execute bracket (ACV1=0EB) 

4. No read permission (ACV4=R-0FF) 
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5. Mo write permission (ACV6=W-0FF) 

6. No execute permission (ACV2=E-0FF) 

7. Invalid ring crossing (ACV12=CRT) 

8. Call limiter fault (ACV7=N0 GA) 

9. Outward call (ACV9=0CALL) 

10. Bad outward call (ACV10=BOC) 

11. Inward return (ACV11=INRET) 

12. Ring alarm (ACV13=RALR) 

13. Associative memory error 

14. Out of segment bounds (ACV15=00SB) 

15. Illegal ring order (ACV0=IR0) 

16. Out of call brackets (ACV8=0CB) 



Group 7 Faults 
Shutdown 



An external power shutdown condition has been detected. DC POWER 
shutdown will occur in approximately one millisecond. 



Timer Runout 



The timer register has decremented to or through the value zero. If 
the processor is in privileged mode or absolute mode, recognition of 
this fault is delayed until a return to normal mode or BAR mode. 
Counting in the timer register continues. 



Connect 



A connect signal ($C0M strobe) has been received from a system 
controller. This event is to be distinguished from a Connect 
Input/Ouput Channel (cioc) instruction encountered in the program 
sequence. 

(See the discussion of the floating faults in Section 3). 

INTERRUPTS AND EXTERNAL FAULTS 

Each system controller contains 32 interrupt cells that are used for 
communication among the active system modules (processors, I/O multiplexers, 
etc.). The interrupt cells are organized in a numbered priority chain. Any 
active system module connected to a system controller port may request the 
setting of an interrupt cell with the SXC system controller command. 

When one or more interrupt cells in a system controller is set, the system 
controller activates the interrupt present (XIP) line to all system controller 
ports having an assigned interrupt mask in which one or more of the interrupt 
cells that are set is unmasked. Interrupt masks should be assigned only to 
processors. Each interrupt cell has associated with it a unique interrupt trap 
pair located at an absolute main memory address equal to twice the cell number. 

Interrupt Sampling 

The processor always fetches instructions in pairs. At an appropriate 
point (as early as possible) in the execution of a pair of instructions, the 
next sequential instruction pair is fetched and held in a special instruction 
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buffer register. The exact point depends on instruction sequence and other 



conditions 



If the interrupt inhibit bit (bit 28) is not set in the current instruction 
word at the point of next sequential instruction pair virtual address formation, 
the processor samples the group 7 faults. If any of the group 7 faults is found 
an internal flag is set reflecting the presence of the fault. The processor 
next samples the interrupt present lines from all eight memory interface ports 
and loads a register with bits corresponding to the states of the lines. If any 
bit in the register is set ON an internal flag is set to reflect the presence of 
the bit(s) in the register. 

If the instruction pair virtual address being formed is the result of a 
transfer of control condition or if the current instruction is Execute (xec), 
Execute Double (xed), Repeat (rpt), Repeat Double (rpd), or Repeat Link (rpl), 
the group 7 faults and interrupt present lines are not sampled. 

At an appropriate point in the execution of the current instruction pair, 
the processor fetches the next instruction pair. At this point, it first tests 
the internal flags for group 7 faults and interrupts. If either flag is set does 
not fetch the next instruction pair. 

At the completion of the current instruction pair the processor once again 
checks the internal flags. If neither flag is set, execution of the next 
instruction pair proceeds. If the internal flag for group 7 faults is set, the 
processor enters a FAULT CYCLE for the highest priority group 7 fault present. 
If the internal flag for interrupts is set, the processor enters an INTERRUPT 
CYCLE. 



Interrupt Cycle Sequence 

In the INTERRUPT CYCLE, the processor safe-stores the Control Unit Data 
(see Section 3) into program-invisible holding registers in preparation for a 
Store Control Unit (sou) instruction, enters temporary absolute mode, and forces 
the current ring of execution C(PPR.PRR) to 0. It then issues an XEC system 
controller command to the system controller on the highest priority port for 
which there is a bit set in the interrupt present register. 

The selected system controller responds by clearing its highest priority 
interrupt cell and returning the interrupt trap pair address for that cell to 
the processor. 

If there is no interrupt cell set in the selected system controller 
(implying that all have been cleared in response to XEC system controller 
commands from other processors) , the system controller returns the address value 
1, which is not a valid interrupt trap pair address. The processor senses this 
value, aborts the INTERRUPT CYCLE, and returns to normal sequential instruction 
processing. 

The interrupt trap pair address returned and the operation code for the 
Execute Double (xed) instruction are forced into the instruction register and 
executed as an instruction. Note that the execution of the instruction is not 
done in a normal EXECUTE CYCLE but in the INTERRUPT CYCLE with the processor in 
temporary absolute mode. 

If the attempt to fetch and execute the instruction pair at the interrupt 
trap pair results in a fault, the INTERRUPT CYCLE is aborted and a FAULT CYCLE 
for the trouble fault (fault number 3D is initiated. In the FAULT CYCLE for a 
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TWaJL H ' he . P rocessop does "£t safe-store the Control Unit Data 
(eZllt V*,? be possible to recover the conditions for the interrupt 
Instr^fl J" tei : r »P t n^ber) by use of the Store Control Unit (scu) 
cS»»»?2 ^ The , int fr ru P fc number may usually be recovered by analysis of the 
regis^s? " f ° r ^ interru P fc tra P P*ir stored in the control unit history 

If either of the two instructions in the interrupt trap oair results in a 
tlToliZ °L C0 . nt /, 0l . t0 a co »P"ted address generated in 'absolute mode, the 
SSJi^JK? by^p^am iltiSf. ° N '^ the tranSfer 3nd remainS ° N the - 3 "- 

If either of the two instructions in the interrupt traD Dair resnn, ir> =, 
ull a lt e \il f 2T£ l* i a , C ° mP ^ ted addreSS «— ™t- in" append moae Uhrough'the 
tK ransfer i S nade i f h ?f i0n H M ° rd , °* 5 y USe of the ifc P or its -odifiers)? 
mode thereafter. PP m ° de a " d and the P poce3sor remains in append 

eff ee J f a t°thI a ?f™f r 2 f *? 0n * r ? 1 takes P lace ' the Processor returns to the node in 
?h- A.* *« * ?f the ^terrupt and resumes normal sequential execution with 
tS-t ?X ruction following the interrupted instruction (C(PPR.IC) t 1) N^te 
IMTEHBW cS7*. B nH K n f ° f e * ecution C(PPR.PRR) was forced to during the 
INTERRPT CYCLE and that normal sequential execution will resume in ring 0. 

additional^ Jrl^T *?*"£** *?* ?*?* ° f the EIS data movement instructions, 
additional group 7 fault and interrupt sampling is done durine these 

u fS" Af H te r. the \ nitial load of the deciraa l unit input data g buf?er? 
formation Th/ nd n,Vn 1 er , rUPt3 < are ""S* f ° r each input op«r«nd vlrtu.1 aSdrlss 
KShS «„ J, 6 instruc V on in execution is interrupted before the operand is 

the^estaM 3'S. YiSS.A'S?. C ° ntr01 ^ *" 3nd De ° imal U " U Data t0 all °« 



NOTE: 



™,iV.J "I , ° f a S - t0re ?oiat * rs and Lengths (spl) instruction is 
ThSiES. f°r 6 it" int 4 ei : ru P ted EIS instruction may be restarted. 
Jn«r^r*' Ul L ° r interrupt handling routine must execute this 
instruction even though it does not use the decimal unit for its 



processing. 



SDft "" y J* fc J e interrupts are deliberately or inadvertently caused by the 
software and do not necessarily involve error conditions. The ooeratine 

XSIni2 0r .* d ? terB , ln !Z the PPOper aCtion for each interrupt by analyzing ' KJ 
Jj«Sii? d «h Vh* ° f , the « P roces3or at the time of the interrupt. In order to 
accomplish this analysis, it is necessary that the first instruction in each of 
the interrupt trap pairs be the Store Control Unit (scu) instruction and the 
ntnin e a ?, tran3fer }° "L int * r W analysis routine, If an interrupt i* to Se 
i^/S ° nal - ly 1 f nored ' the trap pair for that interrupt should contain an 
scu/rcu pair referencing a unique Y-block8. By using this pair to ignore an 

Si? P iVni h H ^V - ° f .^ P rocessor ror the i^ored interrupt may be recovered 1 
if the ignored interrupt causes a trouble fault. The use of the scu/rcu pair 
also ensures that execution is resumed in the original ring of execution 
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SECTION 8 
HARDWARE RING IMPLEMENTATION 



The philosophy of ring protection is based on the existence of a set of 
hierarchical levels of protection. This concept can be illustrated by a set of 
N concentric circles, numbered 0, 1, 2, ..., N-1 from the inside out. The space 
included in circle is called ring 0, the space included between circle i-1 and 
i is called ring i. Any segment in the system is placed in one and only one 
ring. The closer a segment to the center, the greater its protection and 
privilege. 

When a program is executing a procedure segment placed in ring R, the 
program is said to be in ring R, or that the ring of execution or current ring 
is ring R. A program in ring R potentially has access to any segment located in 
ring R and in outer rings. The word "potentially" is used because the final 
decision is subject to what access rights the user has for the target segment. 
This same program in ring R has no access to any segment located in inner rings, 
except to special procedures called gates. 

Gates are procedures residing in a given ring and intended to provide 
controlled access to the ring. A program that is in ring R can enter an inner 
ring r only by calling one of the gate procedures associated with this inner 
ring r. Gates must be carefully coded and must not trust any data that has been 
manufactured or modified by the caller in a less privileged ring. In 
particular, gates must validate all arguments passed to them by the caller so as 
not to compromise the protection of any segment residing in the inner ring. 

Calls from an outer ring to an inner ring are referred to as inward calls. 
They are associated with an increase in the access capability of the program and 
are controlled by gates. Calls from an inner ring to an outer ring, referred to 
as outward calls are associated with a decrease in the access capability of the 
program and do not need to be controlled. 



RING PROTECTION IN MULTICS 

The ring protection designed for Multics uses the foregoing philosophy, 
extended to obtain more flexibility and better efficiency. 
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for a /A ' *f assignment of a segment to one and only one ring is inconvenient 
owrata in «hi™°V h Ure segme " ts ' such as library routines. Such procedures 
ZZllll. l*J»l?r the rXng ° f execution the program is at the time they are 
called, they need no more access than the caller. One solution could have been 
SSltf- ,\°? Py °i th « l«»-ary in each ring. Instead, the solution adopted by 
Till Ha fn«„ a " fc 5 6 condition that a segment can be assigned to only one 
difinf* \l ,1 1 procedure segment to be assigned to a set of consecutive rings 

trim rln^p ° i nt vt g t rS , Cr J» r2) ' Mith r1 <= r2 - If such a segment is callld 
from ring R such that rl <= R <= r2, it behaves as if it were in ring R, and 

ring R such that R > r2, it behaves likes a gate associated with rine r2 
accepting the call as an inward call and decreasing the current ring of the 
program from R to r2. Upon return to the caller, the current ring is Restored 

« n «„ 1 -5?fw ,ld ' A th « . maximum rin S number from which a gate can be called may be 
specified. A third integer, r3, is added to the pair of integers already 
rfnTnnmhir^V s ? gme "V *"* Procedure segment has associated with it three 
ring numbers (rl, r2, r3), called its ring brackets, such that rl <= r2 <= r3. 

than rl iV 1^ Pr fS* I? " * g -f te f ? r ring r2 ' acc essible from rings no higher 
H-n?»J2/ <n , = f 3 ' u th ? P rocedure is n °t a gate. Because outward calls are 
declared illegal in Multics, a segment may be called from a ring R only if 
r1 <s R <= r 3- Such a segment is said to have the call bracket [r1,r3]. 

Third, data segments may also be used in more than one ring. A segment 
resides in ring r1 for write purposes but resides in a less privileged ring r2 

th. r r e e a a d d ffX2.T[\>, r 2 T ' "^^ *" "" t0 ^ '** WPite bra ° ket t0 ' r1] and 

^^„ I" summarv ' t he operations that are potentially permitted to a program in 
ring R on a segment whose ring brackets are (r1, r2, r3) are as follows: 



Write 
Read 
Execute 
Inward call 



if <= R <= r1 

if <= R <= r2 

if r1 <= R <= r2 (execution in ring R) 

if r2 < R <= r3 (execution in ring r2) 



RIMG PROTECTION IN THE PROCESSOR 

The processor provides hardware support for the implementation of Multics 
ring .Protection. A particular effort was made to minimize the overhead 
associated with all authorized ring crossings, which the processor performs 
without operating system intervention; and also to minimize the overhead 
associated with the validation of arguments, for which the processor provides 
assistance. * *««a 

The number of rings available in. the processor is eight, numbered from to 

Iddd ooof Urrent ring R of a Program is recorded in the procedure ring register 
I PPR . PRR ) . 

The ring brackets (r1, r2, r3) of a segment are recorded in the segment 
fu 3Cr on P „ WOrd (SDW) used by the hardware to access the segment. In addition, 
the SDW contains the number of legal gate entries (SDW.CL) existing in the 
segment. The hardware assumes that all gate entries are located from word to 
word (CL-1) and does not permit an inward call to the segment if the word number 
specified in the call is greater than (CL-1). The SDW also contains the access 
rights for the user on the segment. If the same segment is used by several 
users, who may have different access rights to the segment, there is an SDW 
describing the segment in the descriptor segment for each user. 
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In order to provide assistance in argument validation, any pointer being 
stored into an its pointer pair or loaded into a pointer register also contains 
a ring number. A program in ring R may write any value into the ring number 
field of an its pointer pair; the hardware assures that, when a pointer 
register is loaded from an its pointer pair, the ring number loaded is equal to 
or greater than R, but never smaller. 

During the execution of an instruction, the hardware may examine several 
SDWs, its pointer pairs and pointer registers. For any given examination, the 
hardware records the maximum of the current ring, the r1 value found in an SDW, 
the ring number found in an its pointer pair, and the ring number found in a 
pointer register. This maximum is kept in the temporary ring register (TPR.TRR) 
and is updated at each such examination. The reason for having this temporary 
ring number available at any point of instruction execution is that it 
represents the highest ring (least privileged) that might have created or 
modified any information that led the hardware to the target segment it is about 
to reference. Although the current ring is R, the hardware evaluates references 
as if the current ring were C(TPR.TRR), which is always equal to or greater than 
R. The hardware uses C(TPR.TRR) instead of R in all comparisons with the ring 
brackets involved in the enforcement of the ring protection rules given in the 
previous paragraph. 

The use of C(TPR.TRR) by the hardware allows gate procedures to rely on the 
hardware to perform the validation of all addresses passed to the gate by the 
less privileged ring. The rule enforced by the hardware regarding argument 
validation can be stated as follows: 

Whenever an inner ring performs an operation on a given segment and 
references that segment through pointers manufactured by an outer 
ring, the operation is considered valid only if it could have been 
performed while in the outer ring. 



APPENDING UNIT OPERATION WITH RING MECHANISM 

The complete flow chart for effective segment number generation, including 
the hardware ring mechanism, is shown in Figure 8-1 below. See the description 
of the access violation fault in Section 7 for the meanings of the coded faults. 
The current instruction is in the instruction working buffer (IWB). 
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Figure 8-1. Complete Appending Unit Operation Flowchart 



8-4 



AL39 



s SDW for \ 
(TPR.TSR) /* 
in SDWAM? / 



Mo 



Yea 



No/dSBR^U \jfi 



DSPTW 
cycle 



Y£S_/DSPTW.F \ Wo 
~"— \ S et ON? /\ 



< DSPTW. U \ Wo 
set ON? / 



NSDW 
cycle 



I 



Yes 



Initiate a 
directed fault 



MDSPTW 
cycle 



PSDW 
cycle 



JteS. 



Load SDWAM 



I 



<SDW.F \ Wo 
set ON? / I 



Initiate a 
directed fault 



C(SDW.R1)-> 
CCRSDWH.R1) 



I 



Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-5 



AL39 



No 



Set fault 
ACV0=IR0 



CCSDW 
C(SDW 
C(SDW 



.R1) <= \ 
.R2) <= / 



No / \ 

c_r\. 



No 



< 



Yes 



Was last 
cycle an 
rtcd operand 
fetch? 



No / IS OPCODE 
call6? 



/Transfer or \ Yes 

\lnstruction / LJ 1 
\ fetch? / 1 



I 



No 



Yes 







/cc 



No 



<Is it a \ 
STR-OP? A 



les. 



\[TPR.TRR)> 
C(SDW.R2)? 



Yes 



No 



'C(TPR.TRR)> 
C(SDW.R2)? 



Jes. 



Set fault 
ACV3=0RB 



Yes 




No 



Set fault 
ACV5=0WB 



SDW.R 
ON? 



No 



/ SDW.W 
\ ON? 



No 



J*o_/C(PPR.PSR) = 
<C(TPR.TSR)? 



Yes 



Set fault 
ACV4=R-0FF 



Yes 



Set fault 
ACV6=W-0FF 



© 



Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-6 



AL39 



( 



instruction fetch) /"T\ (rtcd operand) 



J2. 



C(TPR.TRR)> \ Ye 
(SDW.R2)? 7*^ 



<C(TPR.TRR)< \ Yes 
C(SDW.RI)? r~**« 



No 



1 



Set fault 
ACVIsOEB 



SDW.E \ No 



\set 


ON? / ' ' """■ 






Yes 


Set fault 
ACV2=E-0FF 















<C(TPR.TRR)>=\ 
C(PPR.PRR)? 7 



No 



Yes 



Set fault 
ACV11=INRET 




RALR \ No 
0? 



Yes /C(PPR.PRR) X No 
< RALR? 



o- 



Yes 



1 



Set fault 
ACV13=RALR 



Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-7 



AL39 



(cal!6) 




Yes 



Set fault 
ACV2=E-0FF 



U£/C(PPR.PSR)= \ 
\C(TPR.TSR)? 7 




No / SDW.G 
ON? 



<C(TPR.CA)„ „\noJ 
>= SDW.CEr ? \ 



Yes 



Yes 



Yes 



Set fault 
ACV7=M0 GA 



Yes 



> SDW.R3? / * 






No 


Set Fault 
ACV8=0CB 


, 






* 







C(TPR.TRR) 
C(PPR.PPR) 



C(TPR.TRR) \ Mo 
< SDW.R1? 



> \ Yes 



No 



C(PPR.PRR) \ Yes 
< SDW.R2? 



No 



Set fault 
ACV10=B0C 



J 



Yes 



Set fault 
ACV9=0CALL 



C(TPR.TRR) \ Yes 
-> SDW.R2? " 



No 



SDW.R2 -> 
C(TPR.TRR) 







Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-8 



AL39 



2 



i?\ (transfer or 

instruction fetch) 



Jsl/c 

C( 



<C(TPR.TRR)> \ Yes 
C(SDW.R2)? /^ 



(TPR.TRRX \ Yes 
(SCW.RD? r-~— 



No 



1 



Set fault 
ACV1=0EB 




SDW.E \ No 

set ON? ^~"~ 



Yes 



Set fault 
ACV2=E-0FF 



I 



I 



No 



Set fault 
ACV12=CRT 



(PPR.PRR)s \ 
(TPR.TRR)? 7 



Yes 



% 



Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-9 



AL39 



1 



C(TPR.CA 
> SDW.BO 



u9d^ 3 \ 



Y£S. 



No 



Set fault 
ACV15=00SB 



No / Anv ACV \ Ye; 
"-~\ faults? 7*-™ 



"*\fault: 

/~^~\ — 

No x is segment \ Yes 
\C(TPR.TSR) 7"""""" 

\H) Yes / is PTW 



1 



Initiate an access 
violation fault 



Yes X is PTW for \ No 
^N^CCTPR.CA) jT^ 

\in PTWAM? / j 



PTW 
cycle 



Yes X Is PTW 
set ON? 



Load 
PTWAM 



.f \ No 

71 



Initiate a 
directed fault 



<Prepage \ 



Yes 



No 



PTW2 
cycle 



Yes 



© 



<Is PTW.F X No 
set ON? / J ' j 



Initiate a 
directed fault 



Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-10 



AL39 



© 



.Yes 



FANP 
cycle 



Was 

an 
word 



I 



MPTW 
cycle 

± 



<STR-OP &\ 
PTW.M=0 7 



No 



FAP 
cycle 



s this Nl 

indirect \Jj 
d fetch? / 



1 



Was it an 
rtcd 
operand 
fetch? 



\ No 



»rand / 

;ch? / X 

I Yes /is OPCODE \ No 

(J) \f_AJ 



I Yes transfer or \ No 
JL ^Instruction / 
/T\ \ fetch? / i, 

\D I / 

Yes XA 

6 ^ 



APU data 
movement? 




No 



Yes 



Load/ store 
APU data 



C 



END APPEND 



D 



Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-11 



AL39 



9 

<ri or ir & \ Yes 
TPR.CA even? Jr**" 



No 



C(Y) 
43 



30,35 
8 



JIS. 



I Yes 

© 



No 



Yes 






/ — * V 

* , \ indirect? / 




Q END APPEND ^ 



Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-12 



AL39 







1 



T7y7 3 17 

C(TPH.'TSR) 
C(Y+1), 17 

cctpr caV 



C(TPR.TRR 
C(PPR.PRR 



No 



i 



<Is OPCODE \ 
tspn? 7 



Yes 



E> 



Yes. 



1 



C(TPR.TRR)-> 
C(PRi.RNR) 
for is0,7 



I 



C(TPR.TRR)-> 
C(PPR.PRR) 



No 



C(PPR.PRR) -> C(PRn.RNR) 
C(PPR.PSR) -> C(PEn.SNR) 
C(PPR.IC) -> C(PRn.WORDNO) 
000000 -> C(PRn.BlTNO) 



CCTPR.TSR)-> 
C(PPR.PSR) 
C(TPR.CA)-> 
C(PPR.IC) 



Yes 



C(SDW.P)-> 
C(PPR.P) 




0->C(PPR.P) 



< 



Is this an 
rtcd 
operand 
fetch? 



C 



No 




END APPEND 



3 



Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-13 



AL39 



£ 



Jes. 



C(TPR.TRR)= 
CCPPR.PRR 



C(PR6.SNR)-> 
C(PR7.SNR) 



E> 



No. 



C(DSBR. STACK) !i C(TPR.TRR) 
-> C(PR7.SNR) 



C(TPR.TRR) -> CCPR7.RMR) 
00... -> C(PR7.W0RDM0) 
000000 -> C(PR7.BITN0) 
C(TPR.TRR) -> C(PPR.PRR) 
C(TPR.TSR) -> C(PPR.PSR) 
C(TPR.CA ) -> C(PPR.IC) 



© 



Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-14 



AL39 



I 



No / C 

RSDWH 



" ^asigiff ~^ Y* 



(TPR.TRR)>=\ 
SDWH.R1? 7 



XftL 



RSDWH. R1-> 
C(TPR.TRR) 



I 



No / C 



C(Y) 1ft , n -> 



pI:?8r: 



c(tpr:trr) 



(TPR.TRR)= \ 
»> 18.20* / 



Yes 



C 



END APPEND 



3 



No 



Mo 



RSDWH. R1-> 
C(TPR.TRR) 



<C(PRn.RN 
RSDWH. R1 



J- 

<C(TPR.TRR)>: 
RSDWH. R1? 



j£S_ 



RNR)>= \ Yes 



I 



No / C 



C(PRn.RNR)-> 
C(TPR.TRR) 



(TPR.TRR)>=\ 
(PRn.RNR)? 7 



Yes 



C 



1 



END APPEND 



J 



Figure 8-1(cont). Complete Appending Unit Operation Flowchart 



8-15 



AL39 



SECTION 9 
CACHE MEMORY OPERATION 



of thS'^nhV 08 proce ! so r mav be fitted with a" optional cache memory. The operation 
of this cache memory is described in this section. p n 

PHILOSOPHY OF CACHE MEMORY 

^ o • J h V!°!? e memorv is a nigh speed buffer memory located within the processor thar 
is intended to hold operands and/or instructions in expectation o "their immediate 
use This concept is different from that of holding a single operand (Such as the 
!w"SetIon 3 d fl iv " e h instruc tion) in the processor during execution of "Until 

"H° fre f e f '-~:^ff«i:-l°. B ti«or ^^^l^^ran-Val^f 

qtaHo T | le calculation of probabilities for a set of values of d requires the 
and VA™ anal y sls of large volumes of real and simulated instruction sequences 

access ti me SVm 3, / f '" ?," be Sh ° Wn that the avera ^ expected data/instruction 
access time reduction (over the range 1 to d) is statistically significant in 

mZrv'Tith t b h i e ooJ Xed - main r" ?? , acce " tlme " then the i-Plementation of /"ache 
performance "" " WlU contrlbute a significant improvement in 




CACHE MEMORY ORGANIZATION 

The cache memory is implemented as 2048 36-bit words of high-speed register 
storage with associated control and content directory circuitry within the processor 

nvi 1 s S ibl e \ 1 o y al 1 f egrated - With the n ° rmal data P ath circuitry and is 'virtual; 
in..„hHf } pro 8 ran ""ing sequences. Parity is generated, stored, and/or checked 

and til hio^f 6renCe - The , t0 - tal St0rage is divided lnt0 512 blocks of U words each 
and the blocks are organized into 128 columns of four levels each. 

Cache Memory/Main Memory Mapping 

g ^ Main memory is mapped into the cache memory as described below and shown in Figure 
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JSoosa^jTsih sa'-is -set:. £ modul ° 128 are grouped 

generated 7 stored, an'HnecK on^ch di^'tory^e^t^y? "^ 1S 

ire-set* Im'?^ n*"^ cons 1 isfcs <"" a 15-bit ADDRESS register a 
pre-set, 2-bit level number value and a level full flag bit. 

S::i\r l th.' 6 S. r Jei b . 1 t°. C d co S lu m °n aded t H int H 3 r° he mem0ry bl0Ck at ««• 

that column %n a d SS Te\ a e \ ed i S C0 \rd;d th wIth lr Y e f ; y a".?.? ^T^ f ° r 
discussed in "Cache Memory Control" later VtVis secUon ? leotlon 1S 
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Main 
Memory 
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Words 

0,3 


Block 

1 

Words 

4,7 


Block 

2 

Words 

8,11 




Block 
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Words 
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Block 

129 

Words 

516,519 


Block 

130 

Words 

520,523 
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Block 
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Words 
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Column 


Column 
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Level 


Level 


Level 















Column 


Column 


Column 







1 


2 




Level 


Level 


Level 




1 


1 


1 




Column 


Column 


Column 







1 


2 




Level 


Level 


Level 




2 


2 


2 




Column 


Column 


Column 







1 


2 




Level 


Level 


Level 




3 


3 


3 







Block 

126 

Words 

50«,507 


Block 

127 

Words 

508,511 




Block 

254 

Words 

1016,1019 


Block 

255 

Words 

1020,1023 





















Block 


Block 




N-2 


N-1 




Words 


Words 




-8,-5 


-4,-1 








Column 


Column 




126 


127 




Level 


Level 







. 




Column 


Column 




126 


127 




Level 


Level 




1 


1 




Column 


Column 




126 


127 




Level 


Level 




2 


2 




Column 


Column 




126 


127 




Level 


Level 




3 


3 



Figure 9-1. Main Memory/Cache Memory Mapping 
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Cache Memory Addressing 

For a read operation, the 24-bit absolute main memory address prepared by 
the appending unit is presented simultaneously to the cache control and to the 
main memory port selection circuitry. While port selection is being 
accomplished, the cache memory is accessed as follows. 

^15,21 are use d to select a cache memory column. 

Y 0,J4 are matched associatively against the four directory ADDRESS 
registers for the selected column. 

If a match occurs for a level whose full flag is ON, a hit is 
signaled, the main memory reference cycle is cancelled, and the level 
number value is read out. 

The level number value and Y^ „ are used to select the level and 
word in the selected column an<Ttni cache memory data is read out into 
the data circuitry. 

If no hit is signaled, the main memory reference cycle proceeds and a 
cache memory block load cycle is initiated (see "Cache Memory Control" 
below) . 

For a write operation, the 24-bit absolute main memory address prepared by 
the appending unit is presented simultaneously to the cache control and to the 
main memory port selection circuitry. While port selection is being 
accomplished, the cache memory is accessed as follows. 

Y 15,21 are use< * to select a cache memory column. 

Y 0.14 are matched associatively against the four directory ADDRESS 
registers for the selected column. 

If a match occurs for a level whose full flag is ON, a hit is signaled 
and the level number value is read out. 

The level number value and Y 22 23 are used to select the level and 
word in the selected column, a 'cache memory write cycle is enabled, 
and the data is written to the main memory and the cache memory 
simultaneously. 

If no hit is signaled, the main memory reference cycle proceeds with 
no further cache memory action. 
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CACHE MEMORY CONTROL 



Enabling and Disabling Cache Memory 

The cache memory is controlled by the state of several bits in the cache 
mode register (see Section 3). The cache mode register may be loaded with the 
Load Central Processor Register (lcpr) instruction. The cache memory control 
bits are as follows: 

bit Value Action 

5*» The lower half of the cache memory (levels and 1) is 

disabled. 
1 The lower half of the cache memory is active and 
enabled as per the state of bits 56-57, 

55 The upper half of the cache memory (levels 2 and 3) is 

disabled. 
1 The upper half of the cache memory is active and 
enabled as per the state of bits 56-57. 

56 The cache memory (if active) is not used for operands 

and indirect words. 
1 The cache memory (if active) is used for operands and 
indirect words. 

57 The cache memory (if active) ijj not used for 

instructions. 
1 The cache memory (if active) is used for instructions. 

59 The cache-to-register mode is not in effect (see 

"Dumping the Cache Memory" later in this section). 
1 The cache-to-register mode is in effect. 

NOTE: The cache memory option furnishes a switch panel maintenance aid that 
attaches to the free edge of the cache memory control logic board. 
The switch panel provides six switches for manual control of the cache 
memory: 

Four of the switches inhibit the control functions of bits 54-57 of 
the cache mode register and have the effect of forcing the 
corresponding function to be disabled. 

The fifth switch inhibits the store-aside feature wherein the 
processor is permitted to proceed immediately after the cache memory 
write cycle on write operations without waiting for a data 
acknowledgement from main memory. (There is no software control 
corresponding to this switch). 

The sixth switch forces the enabled condition on all cache memory 
controls (except eache-to-register mode) without regard to the 
corresponding cache mode register control bit. 

There is no switch corresponding to the cache-to-register control 
bit. 

While these switches are intended primarily for maintenance sessions, 
they have been found useful in testing the cache memory during normal 
operation and in permitting operation of the processor with the cache 
memory in degraded or partially disabled mode. 
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Cache Memory Control in Segment Descriptor Words 

tnfn Certain data have characteristics such that they should never be loaded 
thl T/n °f,i5! ™ erao r y - fc P r i iBap y examples of such data are hardware mailboxes for 
the I/O multiplexed bulk store controller, etc., status return words and 
ll rX ^A 7n f m i° operatin « svste » d ata base segments.' In general, any data' that 
f ^" d * y a " agen °y external to a processor with the intent to convey 
information to that processor should never be loaded into cache memory. 

— „,..!!iLh7i °/ » h t 3egme " t descriptor word is used to reflect this property of 
"encacheability" for each segment. (See Section 5 for a discussion of the 

XH2 t |n?« Cr * 1 h Pt0r r rd ' } If the bit is set 0N ' data from th * »ii»t may K 
loaded into the cache memory; if the bit is OFF, they may not. The operating 
system may set bit 57 ON or OFF as appropriate for the use of the segment? * 

Loading the Cache Memory 

hl . ™ e ° ache m emory is loaded with data implicitly whenever a cache memory 
block load is required. (See the discussion of read operations in "Cache Memory 
Addressing" earlier in this section.) There is no explicit method o? 
instruction to load data into the cache memory. 

When a cache memory block load is required, the level is selected from the 
value of the round robin counter for the selected column, and the cache memory 
write function is enabled. (The round robin counter contains the number of the 
least recently loaded level.) When the data arrives from main memory, it is 
written into the cache memory and entered into the data circuitry. The 
processor proceeds with the execution of the instruction requiring the operand 
it appropriate. 

h • ^?" tl J e caehe memor y "rite is complete, further virtual address formation 
i ii 2 5u £, ?2 is "verted, and a second main memory access for the other 
half of the block is made. When the second half data arrives from main memory, 
it is written into the cache memory, Y ,„ are loaded into the directory ADDRESS 
register, the level full flag is set (fit, the round robin counter is advanced by 
1, and virtual address formation is permitted to proceed. 

If all four level full flags for a column are set ON, a column full flag is 
also set ON and remains ON until one or more levels in the column are cleared. 

Clearing the Cache Memory 

Cache memory can be cleared in two ways; general clear and selective clear. 
The clearing action is the same in both cases, namely, the full flags of the 
selected column(s) and/or level(s) are set OFF. 



GENERAL CLEAR 

The entire cache memory is cleared by setting all column and level full 
flags to OFF in the following situations: 

Upper or lower cache memory or both becoming enabled by appropriate 
bits in the operand of the Load Central Processor Register (lcpr) 
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instruction or by action of the cache memory control logic board free 
edge switches. 

Execution of a Clear Associative Memory Segments (cams) instruction 
with bit 15 of the address field set ON. 



SELECTIVE CLEAR 

The cache memory is cleared selectively as follows: 

If a read-and-clear operation (ldac, sznc, etc.) results in a hit on 
the cache memory, that cache memory block hit is cleared. 

Execution of a Clear Associative Memory Pages (camp) instruction with 
address bit 15 set ON causes Y, 3 14 to be matched against all cache 
directory ADDRESS registers. Alr'caehe memory blocks hit are~eleared. 

Dumping the Cache Memory 

When the cache-to-register mode flag (bit 59 of the cache mode register) is 
set ON, the processor is forced to fetch the operands of all double-precision 
operations unit load operations from the cache memory. Y n 1? are ignored, 
?15,21 select a column, and Y 13 14 select a level. All other operations (e.g., 
instruction fetches, single-precision operands, etc.) are treated normally. 

Note that the phrase "treated normally" as used here includes the case 
where the cache memory is enabled. If the cache memory is enabled, the "other" 
operations causes normal block loads and cache memory writes thus destroying the 
original contents of the cache memory. The cache memory should be disabled 
before dumping is attempted. 

An indexed program loop involving the ldaq and staq instructions with the 
cache-to-register mode bit set ON serves to dump any or all of the cache memory. 

The occurrence of a fault or interrupt sets the cache-to-register mode bit 
to OFF. 
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APPENDIX A 
OPERATION CODE MAP 



A-1. 



This appendix contains the operation code map for the processor in Figure 
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OPERATION CODE MAP (BIT 27 = 0) 



000 
020 
010 
060 
100 
120 
110 
160 



000 



001 




xec 


xed 


qls 


lis 


stq 


staq 


air 


llr 



Figure A-1. Processor Operation Code Map 
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OPERATION CODE MAP (BIT 27 = 1 ) 



J 

040 
060 
100 


000 


001 


002 


OO^i 


004 


0Q5 


006 


007 


010 


011 


012 


01^ 


014 


OTi 








mve 
csl 


csr 






mvne 

sztl 


sztr 


craob 


















■ °>7,. 




120 
140 
160 
200 


scd 
mvt 


scdr 






scm 
tct 


semr 
tctr 


cmpc 










lptr 


sptr 










220 
240 
260 
300 
320 
340 
360 
400 




bfd 


ad2d 
ad3d 


sb2d 
sb3d 






rap2d 
mp3d 


dv2d 
dv3d 


spbpO 


spri 1 


lsdr 
s.pbp2 


spri3 


ssdr 






iptp 














dtb 






easpl 
easp5 
epbpO 
epbD4 


eawpl 
eawp5 
eppl 
epo5 


easp3 
easp7 
epbp2 
epbc6 


eawp3 
eawp7 
epp3 
epp7 












420 
440 
460 
500 


a9bd 






sar eg 
laree 








spl 

lDl 




















520 
540 
560 
600 


s9bd 
araO 
aarO 


s6bd 
aral 

aar 1 


a4bd 
s4bd 
ara2 
aar2 


abd 
sbd 
ara3 
aar 3 


ara4 
aar4 


ara5 
aar5 


ara6 
aar6 


awd 
swd 
ara7 
aar7 






camp 










sptp 




620 
640 
660 
700 


arnO 
narO 


arn 1 
nar 1 


arn2 
nar2 


arn3 
nar 3 


tmoz 

arn4 
nar4 


tpnz 

arn5 
.". ai "5 


ttn 

arn6 
nar6 


arn7 
nar7 


spbp4 


spri5 


spbp6 


spri7 












720 
740 
760 


sarO 
larO 


sar 1 
larl 


sar2 
lar2_| i 


sar3 
lar3 


sar4 I 
lar4 I 


sar5 
lar5 


sar6 
lar6 


sar7 
lar7 I 










sra 
Ira 






















• 




















J 





Figure A-1(cont). Processor Operation Code Map 
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Processor 
Code 


Meaning 


ALM 
keyword 


AR 


Reference through 
pointer register. 


pr 


RL 


Names a register 
containing data length. 


rl 


ID 


Indirect word pointer 


« 



Figure A-2. EIS MF Codes 
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APPENDIX B 



ALPHABETIC OPERATION CODE LIST 



This appendix presents a listing of all processor instruction operation 
codes sorted alphabetically on mnemonic. It also includes the micro operations 
required by the mve and mvne edit instructions. The columns from left to right 
list the mnemonic, octal operation code value, the functional class the page 
number in Section 4 of the instruction description, and the instruction name. 



The functional class codes are: 

FIX Fixed Point 

BOOL Boolean Operations 

FLT Floating Point 

PREG Pointer Register 

PRIV Privileged 

MISC Miscellaneous 

EIS Extended Instruction Set 

TXFR Transfer of Control 

MOP EIS Micro Operations 

Mnemonic Code Class Page Name 



a4bd 
a6bd 
a9bd 
aarn 
abd 

absa 

ad2d 

ad3d 

ada 

adaq 

ade 

adl 

adla 

adlaq 

adlq 

adlxn 

adq 

adwpO 

adwpl 

adwp2 

adwp3 
adwp4 
adwp5 
adwp6 
adwp7 



502(1) 
501(1) 
500(1) 
56n(1) 
503(1) 

212(0) 
202(1) 
222(1) 
075(0) 
077(0) 

415(0) 
033(0) 
035(0) 
037(0) 
036(0) 

02n(0) 
07"5(0) 
050(0) 
051(0) 
052(0) 

053(0) 
150(0) 
151(0) 
152(0) 
153(0) 



EIS 183 Add 4-bit Character Displacement to AR 

EIS 184 Add 6-bit Character Displacement to AR 

EIS 184 Add 9-bit Character Displacement to AR 

EIS 177 Alphanumeric Descriptor to ARn 

EIS 185 Add Bit Displacement to AR 

PRIV 176 Absolute Address to A-Register 

EIS 230 Add Using Two Decimal Operands 

EIS 233 Add Using Three Decimal Operands 

FIX 42 Add to A-Register 

FIX 42 Add to AQ-Register 

FLT 109 Add to Exponent 

FIX 43 Add Low to AQ-Register 

FIX 43 Add Logical to A-Register 

FIX 44 Add Logical to AQ-Register 

FIX 44 Add Logical to Q-Register 

FIX 45 Add Logical to Xn 

FIX 45 Add to Q-Register 

PREG 134 Add to Word Number of PRO 

PREG 134 Add to Word Number of PR1 

PREG 134 Add to Word Number of PR2 

PREG 134 Add to Word Number of PR3 

PREG 134 Add to Word Number of PR4 

PREG 134 Add to Word Number of PR5 

PREG 134 Add to Word Number of PR6 

PREG 134 Add to Word Number of PR7 
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Mnemonic 


Code 


Class 


Page 


adxn 


06n(0 


) FIX 


46 


air 


775(0 


) FIX 


36 


als 


735(0 


) FIX 


36 


ana 


375(0 


) BOOL 


70 


anaq 


377(0 


) BOOL 


70 


anq 


376(0 


) BOOL 


71 


ansa 


355(0 


) BOOL 


71 


ansq 


356(0 


) BOOL 


72 


ansxn 


34n(0 


) BOOL 


72 


anxn 


36n(0 


) BOOL 


73 


aos 


051(0 


) FIX 


46 


aran 


54n(1 


) EIS 


180 


arl 


771(0 


) FIX 


37 


arnn 


64n(1 


) EIS 


180 


ars 


73KO 


) FIX 


37 


asa 


055(0 


> FIX 


46 


asq 


056(0 


) FIX 


47 


asxn 


04n(0' 


) FIX 


47 


awe a 


07T(0" 


> FIX 


48 


aweq 


072(0: 


» FIX 


48 


awd 


507(1] 


> EIS 


186 


bed 


505(0: 


MISC 


155 


btd 


30K1: 


EIS 


226 


call6 


713(0! 


TXFR 


111 


camp 


532(1] 


PRIV 


168 


cams 


532(0! 


PRIV 


168 


cana 


315(0) 


BOOL 


82 


canaq 


317(0) 


BOOL 


82 


canq 


316(0! 


BOOL 


83 


canxn 


30n(0) 


BOOL 


83 


cioc 


015(0) 


PRIV 


173 


cmg 


405(0) 


FIX 


64 


cmk 


211(0) 


FIX 


64 


empa 


115(0) 


FIX 


65 


empaq 


117(0) 


FIX 


65 


empb 


066(1) 


EIS 


222 


empc 


106(1) 


EIS 


191 


empn 


303(1! 


EIS 


210 


empq 


116(0) 


FIX 


66 


empxn 


10n(0) 


FIX 


67 


cnaa 


215(0) 


BOOL 


84 


cnaaq 


217(0) 


BOOL 


84 


cnaq 


216(0) 


BOOL 


84 


cnaxn 


20n(0) 


BOOL 


85 


csl 


06S(1) 


EIS 


218 


csr 


061(1) 


EIS 


220 


cwl 


111(0) 


FIX 


68 


dfad 


177(0) 


FLT 


90 


dfcmg 


427(0) 


FLT 


107 


dfemp 


517(0) 


FLT 


107 


dfdi 


527(0) 


FLT 


99 


dfdv 


567(0) 


FLT 


99 


dfld 


433(0) 


FLT 


86 


dfmp 


463(0) 


FLT 


96 


dfrd 


473(0) 


FLT 


105 



Name 



Add to Xn 

A-Register Left Rotate 
A-Register Left Shift 
AND to A-Register 
AND to AQ-Register 

AND to Q-Register 

AND to Storage from A-Register 

AND to Storage from Q-Register 

AND to Storage from Xn 

AND to Xn 

Add One to Storage 
ARn to Alphanumeric Descriptor 
A-Register Right Logical Shift 
ARn to Numeric Descriptor 
A-Register Right Shift 

Add Stored to A-Register 
Add Stored to Q-Register 
Add Stored to Xn 
Add With Carry to A-Register 
Add With Carry to Q-Register 

Add Word Displacement to AR 
Binary-to-BCD 
Binary-to-Decimal Convert 
Call (using PR6 and PR7) 
Clear Associative Memory Pages 

1 Clear Associative Memory Segments 
Comparative AND with A-Register 
Comparative AND with AQ-Register 
Comparative AND with Q-Register 
Comparative AND with Xn 

Connect Input/Output Channel 

Compare Magnitude 

Compare Masked 

Compare with A-Register 

Compare with AQ-Register 

Compare Bit Strings 

Compare Alphanumeric Character Strings 

Compare Numeric 

Compare with Q-Register 

Compare with Xn 

Comparative NOT with A-Register 
Comparative NOT with AQ-Register 
Comparative NOT with Q-Register 
Comparative NOT with Xn 
Combine Bit Strings LeTt 

Combine Bit Strings Right 
Compare With Limits 
Double-Precision Floating Add 
Double-Precision Floating Compare Magnitude 
Double-Precision Floating Compare 

Double-Precision Floating Divide Inverted 

Double-Precision Floating Divide 

Double-Precision Floating Load 

Double-Precision Floating Multiply 

Double-Precision Floating Round 



2/82 



B-2 



AL39B 



Mnemonic Code Class Page Name 



dfsb 


577(0 


) FLT 


93 


dfst 


457(0 


) FLT 


87 


dfstr 


472(0 


) FLT 


87 


dis 


616(0 


) PRIV 


176 


div 


506(0 


) FIX 


59 


drl 


002(0 


) MISC 


137 


dtb 


305(1 


) EIS 


228 


dufa 


437(0 


) FLT 


90 


dufm 


423(0 


) FLT 


96 


dufs 


537(0 


) FLT 


93 


dv2d 


207(1 


) EIS 


242 


dv3d 


227(1 


) EIS 


243 


dvf 


507(0 


) FIX 


60 


eaa 


635(0 


) FIX 


16 


eaq 


636(0 


) FIX 


16 


easpO 


31K0 


) PREG 


124 


easpl 


310(1 


) PREG 


124 


easp2 


313(0 


) PREG 


124 


easp3 


312(1 


) PREG 


124 


easpl 


33KO 


) PREG 


124 


easp5 


330(1 


) PREG 


124 


easp6 


333(0 


) PREG 


124 


easp7 


332(1 


) PREG 


124 


eawpO 


310(0 


) PREG 


125 


eawpl 


311(1 


) PREG 


125 


eawp2 


312(0 


) PREG 


125 


eawp3 


313(1 


) PREG 


125 


eawpl 


330(0 


) PREG 


125 


eawp5 


33K1 


) PREG 


125 


eawpo 


332(0 


I PREG 


125 


eawp7 


333(1 


t PREG 


125 


eaxn 


62n(0' 


FIX 


17 


epaq 


213(0' 


PREG 


135 


epbpO 


350(1 


) PREG 


126 


epbpl 


351(0' 


PREG 


126 


epbp2 


352(1: 


PREG 


126 


epbp3 


353(0: 


PREG 


126 


epbpl 


370(1: 


PREG 


126 


epbp5 


37K0: 


PREG 


126 


epbp6 


372(1: 


PREG 


126 


epbp7 


373(0: 


PREG 


126 


eppO 


350(0: 


PREG 


127 


eppl 


351(1 : 


PREG 


127 


epp2 


352(0! 


PREG 


127 


epp3 


353(11 


PREG 


127 


epp4 


370(0] 


PREG 


127 


epp5 


371(1] 


PREG 


127 


epp6 


372(0] 


PREG 


127 


epp7 


373(1] 


PREG 


127 


era 


675(0] 


BOOL 


78 


eraq 


677(0] 


BOOL 


78 


erq 


676(0] 


BOOL 


79 


ersa 


655(0] 


BOOL 


79 


ersq 


656(0) 


BOOL 


80 


ersxn 


64n(0) 


BOOL 


80 



Double-Precision Floating Subtract 
Double-Precision Floating Store 
Double-Precision Floating Store Rounded 
Delay Until Interrupt Signal 
Divide Integer 

Derail 

Decimal-to-Binary Convert 

Double-Precision Unnormalized Floating Add 

Double-Precision Unnormalized Floating Multiply 

Double-Precision Unnormalized Floating Subtract 

Divide Using Two Decimal Operands 
Divide Using Three Decimal Operands 
Divide Fraction 

Effective Address to A-Register 
Effective Address to Q-Register 

Effective Address to Segment Number of PRO 

Effective Address to Segment Number of PR1 

Effective Address to Segment Number of PR2 

Effective Address to Segment Number of PR3 

Effective Address to Segment Number of PR4 

Effective Address to Segment Number of PR5 

Effective Address to Segment Number of PR6 

Effective Address to Segment Number of PR7 

Effective Address to Word/Bit Number of PRO 

Effective Address to Word/Bit Number of PR1 

Effective Address to Word/Bit Number of PR2 
Effective Address to Word/Bit Number of PR3 
Effective Address to Word/Bit Number of PR4 
Effective Address to Word/Bit Number of PR5 
Effective Address to Word/Bit Number of PR6 

Effective Address to Word/Bit Number of PR7 
Effective Address to Xn 
Effective Pointer to AQ-Register 
Effective Pointer at Base to PRO 
Effective Pointer at Base to PR1 

Effective Pointer at Base to PR2 
Effective Pointer at Base to PR3 
Effective Pointer at Base to PR4 
Effective Pointer at Base to PR5 
Effective Pointer at Base to PR6 

Effective Pointer at Base to PR7 
Effective Pointer to PRO 
Effective Pointer to PR1 
Effective Pointer to PR2 
Effective Pointer to PR3 

Effective Pointer to PR4 
Effective Pointer to PR5 
Effective Pointer to PR6 
Effective Pointer to PR7 
Exclusive OR to A-Register 

Exclusive OR to AQ-Register 

Exclusive OR to Q-Register 

Exclusive OR to Storage with A-Register 

Exclusive OR to Storage with Q-Register 

Exclusive OR to Storage with Xn 
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Mnemonic 


Code 


Class 


Page 


erxn 


66n(0] 


BOOL 


81 


fad 


475(0: 


FLT 


91 


fcmg 


425(0) 


FLT 


108 


fcrap 


515(01 


FLT 


108 


fdi 


525(0) 


FLT 


100 


fdv 


565(0) 


FLT 


101 


fid 


431(0: 


FLT 


86 


fmp 


461(0) 


FLT 


97 


fneg 


513(0: 


FLT 


103 


fno 


573(0) 


FLT 


104 


frd 


47K0) 


FLT 


105 


fsb 


575(0; 


FLT 


94 


fst 


455(0) 


FLT 


88 


fstr 


470(0) 


FLT 


88 


fszn 


430(0) 


FLT 


109 


gtb 


774(0) 


MISC 


156 


larn 


76n(1) 


EIS 


178 


lareg 


463(1) 


EIS 


178 


lbar 


230(0) 


FIX 


157 


lea 


335(0) 


FIX 


17 


lcaq 


337(0) 


FIX 


18 


lepr 


674(0) 


PRIV 


157 


lcq 


336(0) 


FIX 


18 


lexn 


32n(0) 


FIX 


19 


Ida 


235(0) 


FIX 


19 


ldac 


034(0! 


FIX 


20 


ldaq 


237(0) 


FIX 


20 


ldbr 


232(0) 


PRIV 


158 


lde 


411(0) 


FLT 


109 


ldi 


634(0) 


FIX 


21 


ldq 


236(0) 


FIX 


22 


ldqc 


032(0) 


FIX 


22 


ldt 


637(0) 


PRIV 


159 


ldxn 


22n(0) 


FIX 


23 


llr 


777(0) 


FIX 


38 


lis 


737(0) 


FIX 


38 


lpl 


467(1' 


EIS 


178 


lpri 


173(0) 


PREG 


128 


lprpn 


76n(0) 


PREG 


128 


lptp 


257(1' 


PRIV 


159 


lptr 


173(1' 


PRIV 


160 


Ira 


774(1 


» PRIV 


160 


lreg 


073(0 


FIX 


23 


lrl 


773(0' 


FIX 


39 


Irs 


733(0 


t FIX 


39 


lsdp 


257(0' 


PRIV 


161 


lsdr 


232(1 


) PRIV 


161 


lxln 


72n(0 


» FIX 


24 


mlr 


1075(1 


) EIS 


202 


mme 


001(0 


) MISC 


140 


mme2 


004(0 


) MISC 


141 


mme 3 


005(0 


) MISC 


141 


mme 4 


007(0 


) MISC 


142 


mp2d 


206(1 


) EIS 


239 


rap3d 


226(1 


) EIS 


240 



Name 



Exclusive OR to Xn 
Floating Add 

Floating Compare Magnitude 
Floating Compare 
Floating Divide Inverted 

Floating Divide 
FLoating Load 
Floating Multiply 
Floating Negate 
Floating Normalize 

Floating Round 

Floating Subtract 

Floating Store 

Floating Store Rounded 

Floating Set Zero and Negative Indicators 

Gray-to-Binary Convert 

Load ARn 

Load ARs 

Load BAR 

Load Complement into A-Register 

Load Complement into AQ-Register 
1 Load Central Processor Register 
Load Complement into Q-Register 
Load Complement into Xn 
Load A-Register 

Load A-Register and Clear 

Load AQ-Register 

Load Descriptor Base Register 

Load Exponent 

Load IR 

Load Q-Register 

Load Q-Register and Clear 

Load Timer Register 

Load Xn 

Long Left Rotate 

Long Left Shift 
Load Pointers and Lengths 
Load PRs from ITS Pairs 
Load PRn from Packed Pointer 
Load Page Table Pointers 

Load Page Table Registers 

Load Ring Alarm Register 

Load Registers 

Long Right Logical 

Long Right Shift 

Load Segment Descriptor Pointers 
Load Segment Descriptor Registers 
Load Xn from Lower 
Move ATphanumeric Left to Right 
Master Mode Entry 

Master Mode Entry 2 

Master Mode Entry 3 

Master Mode Entry 4 

Multiply Using Two Decimal Operands 

Multiply Using Three Decimal Operands 



2/82 



B-4 



AL39B 



Mnemonic 


Code C 


:iass I 


'age 


mpf 


401(0) 


FIX 


57 


mpy 


402(0) 


FIX 


57 


mrl 


101(1) 


EIS 


204 


mve 


020C1) 


EIS 


205 


mvn 


300(1) 


EIS 


213 


mvne 


024(1) 


EIS 


216 


mvt 


160(1) 


EIS 


207 


narn 


66n(1) 


EIS 


179 


neg 


53"T(0) 


FIX 


62 


negl 


533(0) 


FIX 


62 


nop 


011(0) 


MISC 


143 


ora 


275(0) 


BOOL 


74 


oraq 


274(0) 


BOOL 


74 


orq 


276(0) 


BOOL 


75 


orsa 


255(0) 


BOOL 


75 


orsq 


256(0) 


BOOL 


76 


orsxn 


24n(0) 


BOOL 


76 


orxn 


26n(0) 


BOOL 


77 


pulsl 


011(0) 


MISC 


143 


puls2 


013(0) 


MISC 


144 


qlr 


776(0) 


FIX 


40 


qls 


736(0) 


FIX 


40 


qrl 


772(0) 


FIX 


41 


qrs 


732(0) 


FIX 


41 


reel 


633(0) 


MISC 


136 


rcu 


613(0) 


PRIV 


162 


ret 


630(0) 


TXFR 


112 


rmem 


233(0) 


PRIV 


170 


rpd 


560(0) 


MISC 


145 


rpl 


500(0) 


MISC 


148 


rpt 


520(0) 


MISC 


150 


rscr 


413(0) 


PRIV 


170 


rsw 


23K0) 


PRIV 


171 


rtcd 


610(0) 


TXFR 


113 


s4bd 


522(1) 


EIS 


187 


s6bd 


521(1) 


EIS 


188 


s9bd 


520(1) 


EIS 


188 


sarn 


74n(1) 


EIS 


181 


sareg 


441(1) 


EIS 


182 


sb2d 


203(1) 


EIS 


236 


sb3d 


223(1) 


EIS 


237 


sba 


175(0) 


FIX 


50 


sbaq 


177(0) 


FIX 


50 


sbar 


550(0) 


MISC 


154 


sbd 


523(1) 


EIS 


189 


sbla 


135(0) 


FIX 


50 


sblaq 


137(0) 


FIX 


51 


sblq 


136(0) 


FIX 


51 


sblxn 


12n(0) 


FIX 


52 


sbq 


175(0) 


FIX 


52 


sbxn 


I6n(0) 


FIX 


53 


scd 


120"(1) 


EIS 


193 


scdr 


121(1) 


EIS 


194 


scm 


124(1) 


EIS 


196 


scrar 


125(1) 


EIS 


198 



Name 



Multiply Fraction 

Multiply Integer 

Move Alphanumeric Right to Left 

Move Alphanumeric Edited 

Move Numeric 

Move Numeric Edited 

Move Alphanumeric with Translation 

Numeric Descriptor to ARji 

Negate (A-Register) 

Negate Long (AQ-Register) 

No Operation 

OR to A-Register 

OR to AQ-Register 

OR to Q-Register 

OR to Storage from A-Register 

OR to Storage from Q-Register 

OR to Storage from Xn 

OR to Xn 

Pulse 1 

Pulse 2 

Q-Register Left Rotate 
Q-Register Left Shift 
Q-Register Right Logical Shift 
Q-Register Right Shift 
Read Calendar Clock 

Restore Control Unit 

Return 

Read Memory Controller Mask 

Repeat Double 

Repeat Link 

Repeat 

Read System Controller Register 

Read Switches 

Return Control Double 

Subtract 4-bit Displacement from AR 

Subtract 6-bit Displacement from AR 

Subtract 9-bit Displacement from AR 

Store ARn 

Store ARs 

Subtract Using Two Decimal Operands 

Subtract Using Three Decimal Operands 

Subtract from A-Register 

Subtract from AQ-Register 

Store BAR 

Subtract Bit Displacement from AR 

Subtract Logical from A-Register 
Subtract Logical from AQ-Register 
Subtract Logical from Q-Register 
Subtract Logical from Xn 
Subtract from Q-Register 

Subtract from Xn 

Scan Character Uouble 

Scan Character Double Reverse 

Scan With Mask 

Scan With Mask Reverse 
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Mnemonic Code Class Page Name 



scpr 


452(0) 


PRIV 


163 


scu 


657(0) 


PRIV 


164 


sdbr 


154(0) 


PRIV 


164 


smcm 


553(0) 


PRIV 


173 


smic 


451(0) 


PRIV 


174 


spbpO 


250(1) 


PREG 


130 


spbpl 


251(0) 


PREG 


130 


spbp2 


252(1) 


PREG 


130 


spbp3 


253(0) 


PREG 


130 


spbp4 


650(1) 


PREG 


130 


spbp5 


651(0) 


PREG 


130 


spbp6 


652(1) 


PREG 


130 


spbp7 


653(0) 


PREG 


130 


spl 


447(1) 


EIS 


182 


spr i 


254(0) 


PREG 


131 


spriO 


250(0) 


PREG 


132 


spr i1 


251(1) 


PREG 


132 


spr 12 


252(0) 


PREG 


132 


spr i3 


253(1) 


PREG 


132 


spr i4 


650(0) 


PREG 


132 


spr i5 


651(1) 


PREG 


132 


spr i6 


652(0) 


PREG 


132 


spr i7 


653(1) 


PREG 


132 


sprpn 


54n(0) 


PREG 


133 


sptp 


557( 1 ) 


PRIV 


165 


sptr 


154(1) 


PRIV 


165 


sra 


754(1) 


MISC 


153 


sreg 


753(0) 


FIX 


25 


ssa 


155(0) 


FIX 


53 


sscr 


057(0) 


PRIV 


174 


ssdp 


557(0) 


PRIV 


165 


ssdr 


254(1: 


PRIV 


166 


ssq 


154(0) 


FIX 


54 


ssxn 


14n(o: 


FIX 


54 


sta 


755(0] 


FIX 


26 


stac 


354(0 


) FIX 


26 


stacq 


654(0 


) FIX 


27 


staq 


757(0 


) FIX 


27 


stba 


551(0 


) FIX 


28 


stbq 


552(0 


) FIX 


29 


std 


554(0 


) FIX 


29 


stc2 


750(0 


) FIX 


30 


stca 


751(0 


) FIX 


30 


stcd 


357(0 


) FIX 


32 


stcq 


752(0 


) FIX 


31 


ste 


456(0 


) FLT 


110 


sti 


754(0 


) FIX 


32 


stq 


756(0 


) FIX 


33 


stt 


454(0 


) FIX 


33 


stxji 


74n(0 


) FIX 


34 


stz 


450(0 


) FIX 


34 


swca 


17K0 


) FIX 


55 


swcq 


172(0 


) FIX 


55 


swd 


527(1 


) EIS 


190 


sxln 


44n(0 


) FIX 


31 



Store Central Processor Register 
Store Control Unit 
Store Descriptor Base Register 
Set Memory Controller Mask 
Set Memory Interrupt Cells 

Store Segment Base Pointer of PRO 

Store Segment Base Pointer of PR1 

Store Segment Base Pointer of PR2 

Store Segment Base Pointer of PR3 

Store Segment Base Pointer of PR4 

Store Segment Base Pointer of PR5 

Store Segment Base Pointer of PR6 

Store Segment Base Pointer of PR7 

Store Pointers and Lengths 

Store PRs as ITS Pairs 

Store PRO as an ITS Pair 

Store PR1 as an ITS Pair 

Store PR2 as an ITS Pair 

Store PR3 as an ITS Pair 

Store PR4 as an ITS Pair 

Store PR5 as an ITS Pair 

Store PR6 as an ITS Pair 

Store PR7 as an ITS Pair 

Store PRn as a Packed Pointer 

Store Page Table Pointers 

1 Store Page Table Registers 
Store Ring Alarm Register 
Store Registers 

Subtract Stored from A-Register 
Set System Controller Register 

2 Store Segment Descriptor Pointers 
Store Segment Descriptor Registers 
Subtract Stored from Q-Register 
Subtract Stored from Xn 

Store A-Register 

Store A-Register Conditional 

Store A-Register Conditional on Q-Register 

Store AQ-Register 

Store 9-bit Bytes of A-Register 

Store 9-bit Bytes of Q-Register 

Store Instruction Counter + 1 

Store Instruction Counter + 2 

Store 6-bit Characters of A-Register 

Store Control Double 

Store 6-bit Characters of Q-Register 

Store Exponent 
Store IR 

Store Q-Register 
Store Timer Register 
Store Xn 

Store Zero 

Subtract With Carry from A-Register 
Subtract With Carry from Q-Register 
Subtract Word Displacement from AR 
Store Xn in Lower 
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szn 

sznc 

sztl 

sztr 

tct 

tctr 

teo 

teu 

tmi 

tmoz 

tnc 
tnz 
tov 
tpl 
tpnz 

tra 

trc 

trtf 

trtn 

tspO 

tspl 
tsp2 
tsp3 
tsp4 
tsp5 

tsp6 
tsp7 
bss 
tsxji 

ttf 

ttn 
tze 
ufa 
ufm 
ufs 

xec 
xed 



231(0) 
214(0) 
064(1) 
065(1) 
161(1) 

165(1) 
614(0) 
615(0) 
604(0) 
604(1) 

602(0) 
601(0) 
617(0) 
605(0) 
605(1) 

710(0) 
603(0) 
601(1) 
600(1) 
270(0) 

27K0) 
272(0) 
273(0) 
670(0) 
671(0) 

672(0) 
673(0) 
715(0) 
70n(0) 
607(0) 

606(1) 
600(0) 
435(0) 
421(0) 
535(0) 

716(0) 
717(0) 



FIX 69 Set Zero and Negative Indicators 

FIX 69 Set Zero and Negative Indicators and Clear 

EIS 224 Set Zero/Truncation Indicators with Bit String Left 

EIS 225 Set Zero/Truncation Indicators with Bit String Right 

EIS 199 Test Character and Translate 

Test Character and Translate Reverse 
Transfer on Exponent Overflow 
Transfer on Exponent Underflow 
Transfer on Minus 
Transfer on Minus or Zero 

Transfer on No Carry 
Transfer on Nonzero 
Transfer on Overflow 
Transfer on Plus 
Transfer on Plus and Nonzero 



EIS 

TXFR 

TXFR 

TXFR 

TXFR 

TXFR 
TXFR 
TXFR 
TXFR 
TXFR 

TXFR 
TXFR 
TXFR 
TXFR 
TXFR 

TXFR 
TXFR 
TXFR 
TXFR 
TXFR 

TXFR 
TXFR 
TXFR 
TXFR 
TXFR 

TXFR 

TXFR 

FLT 

FLT 

FLT 

MISC 
MISC 



201 
114 
114 
115 
115 

115 
116 
116 
117 
117 

118 
118 
118 
119 
120 

120 
120 
120 
120 

120 

120 
120 
120 
121 
122 

122 

122 

91 

98 

95 

138 
139 



Transfer 

Transfer on Carry 

Transfer on Truncation Indicator Off 

Transfer on Truncation Indicator On 

Transfer and Set PRO 

Transfer and Set PR1 
Transfer and Set PR2 
Transfer and Set PR3 
Transfer and Set PR4 
Transfer and Set PR5 

Transfer and Set PR6 

Transfer and Set PR7 

Transfer and Set Slave 

Transfer and Set Xn 

Transfer on Tally "Runout Indicator Off 

Transfer on Tally Runout Indicator On 
Transfer on Zero 
Unnormalized Floating Add 
Unnormalized Floating Multiply 
Unnormalized Floating Subtract 

Execute 
Execute Double 



EIS Micro Operations 



cht 

enf 

ign 

insa 

insb 

insm 

insn 

insp 

lte 

mflc 

mfls 

mors 

mses 

mve 

mvza 



21 
02 
14 
11 
10 

01 
12 
13 
20 
07 

06 
17 
16 
15 
05 



MOP 249 Change Table 

MOP 249 End Floating Suppression 

MOP 250 Ignore Source Character 

MOP 250 Insert Asterisk on Suppression 

MOP 251 Insert Blank on Suppression 

MOP 251 Insert Table Entry 1 Multiple 

MOP 251 Insert on Negative 

MOP 252 Insert on Positive 

MOP 252 Load Table Entry 

MOP 253 Move with Float Currency Symbol Insertion 

MOP 253 Move with Float Sign Insertion 

MOP 254 Move and OR Sign 

MOP 255 Move and Set Sign 

MOP 255 Move Source Character , 

MOP 256 Move with Zero Suppression and Asterisk Replacement | 



I 
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mvzb 04 MOP 256 Move with Zero Suppression and Blank Replacement 
| ses 03 MOP 257 Set End Suppression 
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APPENDIX C 



ADDRESS MODIFIERS 



00 
10 
20 
30 
40 
50 
60 
70 



00 


01 


02 


0? 


04 


0«5 


06 


07 


o 


au 

1 


qu 

2 


du 


ic 
4 


al 

•> 


6 


dl 

7 


n* 

0* 


au* 
1* 


qu* 
2* 


V 


io* 

4* 


al* 

5* 


ql* 
6* 


7* 


f1 
ci 


itp 
i 


sc 


its 
ad 


sd 

di 


scr 
die 


f2 
id 


f3 

idc 


*n 
*0 


*au 
•1 


*qu 
*2 


*du 
*1 


*ic 
*4 


*al 
*<S 


*ql 
*6 


*dl 
*7 



r 

ri 
it 
ir 



NONSTANDARD MODIFIERS 



Instruction Tag 



scpr 



lepr 

stca 
stcq 
stba 
stbq 



00 
01 
06 
10 
20 
40 

02 
03 
04 
07 



Meaning 

Store appending unit history register 

Store fault register 

Store mode register 

Store decimal unit history register 

Store control unit history register 

Store operations unit history register 

Load cache mode register 

Load 0s into all history registers 

Load mode register 

Load 1s into all history registers 

See description in Section 4 

See description in Section 4 

See description in Section 4 

See description in Section 4 
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Arithmetic 4-183 
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Pointer Register Address Arithmetic 
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BASE 

base address register 1-4 

Base Address Register (BAR) 3-9 
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(DSBR) 3-16 
Store Base Address Register 4-154 

BASIC 
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Boolean EXCLUSIVE OR 4-78 

BOOLEAN OPERATION INSTRUCTIONS 4-70 

Boolean OR 4-74 

CACHE 9-5 

Cache Memory Control in Segment 

Descriptor Words 9-6 
Cache Mode Register (CMR) - DPS and 
L68 3-32 



CODE 

Micro Operation Code Assignment Map 

4-257 
mnemonic code 4-2 

COMBINE 

EIS - Bit String Combine 4-218 

COMMON 

Common Computed Address Formation 
6-6 

COMPARATIVE 

Boolean Comparative AND 4-82 
Boolean Comparative NOT 4-84 

COMPARE 

EIS - Alphanumeric Compare 4-191 
EIS - Bit String Compare 4-222 
EIS - Numeric Compare 4-210 
Floating-Point Compare 4-107 

COMPARISON 

Fixed-Point Comparison 4-64 

COMPUTED 

Common Computed Address Formation 

6-6 
General Computed Address 

Modification Types 6-5 

CONFIGURATION 

Configuration Switch Data - DPS 8M 

3-56 
Configuration Switch Data - DPS and 

L68 3-54 
Privileged - Configuration and 

Status 4-170 

CONTROL 

Cache Memory Control in Segment 

Descriptor Words 9-6 
Control Unit 1-4 
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CONTROL (cont) 

Control Unit (CU) History Register - 

DPS 8M 3-39 

Control Unit (CU) History Register - 

DPS and L68 3-37 

Control Unit Data 3-58 

Privileged - System Control 4-173 

CONVERSION 

EIS - Data Conversion 4-226 

CU 

Control Unit (CU) History Register - 

DPS 8M 3-39 

Control Unit (CU) History Register - 

DPS and L68 3-37 

CYCLE 

FAULT CYCLE SEQUENCE 7-1 

DATA 

Alphanumeric data 2-12 
APPENDING UNIT DATA WORD FORMATS 

5-9 
Configuration Switch Data - DPS 8M 

3-56 
Configuration Switch Data - DPS and 

L68 3-54 
Control Unit Data 3-58 
DATA PARITY 2-4 
DECIMAL DATA 2-9 
Decimal Unit Data 3-63 
EIS - Data Conversion 4-226 
FIXED-POINT BINARY DATA 2-4 
Fixed-Point Data Movement Load 4-16 
Fixed-Point Data Movement Shift 

4-36 
Fixed-Point Data Movement Store 

4-25 
FLOATING-POINT BINARY DATA 2-6 
Floating-Point Data Movement Load 

4-86 
Floating-Point Data Movement Store 

4-87 
Pointer Register Data Movement Load 

4-124 
Pointer Register Data Movement Store 
4-130 

DECIMAL 

DECIMAL DATA 2-9 

Decimal Unit 1-5 

Decimal Unit Data 3-63 

Decimal unit history register 3-43 

EIS - Decimal Addition 4-230 

EIS - Decimal Division 4-242 

EIS - Decimal Multiplication 4-239 

EIS - Decimal Subtraction 4-236 

Decimal/Operations (DU/OU) History 
Register - DPS 8M 3-46 



Derail 4-137 

DESCRIPTIONS 

FAULT DESCRIPTIONS 
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DESCRIPTOR 

ALPHANUMERIC OPERAND DESCRIPTOR 

FORMAT 4-12 
BIT-STRING OPERAND DESCRIPTOR FORMAT 

4-15 
Cache Memory Control in Segment 

Descriptor Words 9-6 
Descriptor Segment Base Register 

(DSBR) 3-16 
NUMERIC OPERAND DESCRIPTOR FORMAT 

4-13 
OPERAND DESCRIPTOR INDIRECT POINTER 

FORMAT 4-11.1 
Segment Descriptor Word (SDW) Format 

5-9 
Segment Descriptor Word Associative 

Memory (SDWAM) - DPS/L68 and 

DPS 8M 3-18 

DIFFERENCES 

MVNE and MVE Differences 4-248 

DIVISION 

EIS - Decimal Division 4-242 
Fixed-Point Division 4-59 
Floating-Point Division 4-99 

DPS 

Appending Unit (APU) History 

Register - DPS 8M 3-51 
Appending Unit (APU) History 

Register - DPS and L68 3-49 
Cache Mode Register (CMR) - DPS and 

L68 3-32 
Configuration Switch Data - DPS 8M 

3-56 
Configuration Switch Data - DPS and 

L68 3-54 
Control Unit (CU) History Register - 

DPS 8M 3-39 
Control Unit (CU) History Register - 

DPS and L68 3-37 
Fault Register (FR) - DPS and L68 

3-23 
Mode Register (MR) - DPS and L68 

3-27 
Segment Descriptor Word Associative 

Memory (SDWAM)' - DPS/L68 and 

DPS 8M 3-18 

DPS/L68 

Segment Descriptor Word Associative 
Memory (SDWAM) - DPS/L68 and 
DPS 8M 3-18 

DSBR 

Descriptor Segment Base Register 
(DSBR) 3-16 



Exponent Register (E) 3-4 

EAQ 

Exponent- Accumulator-Quotient 
Register (EAQ) 3-4 

EDIT 

ALPHANUMERIC EDIT 4-248 
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EDIT (cont) 

edit flags 4-247 
edit insertion table 4-246 
-. NUMERIC EDIT 4-248 

EFFECTIVE 

effective segment number generation 
6-22 

EIS 

EIS - Address Register Load 4-177 
EIS - Address Register Special 

Arithmetic 4-183 
EIS - Address Register Store 4-180 
EIS - Alphanumeric Compare 4-191 
EIS - Alphanumeric Move 4-202 
EIS - Bit String Combine 4-218 
EIS - Bit String Compare 4-222 
EIS - Bit String Set Indicators 

4-224 
EIS - Data Conversion 4-226 
EIS - Decimal Addition 4-230 
EIS - Decimal Division 4-242 
EIS - Decimal Multiplication 4-239 
EIS - Decimal Subtraction 4-236 
EIS - Numeric Compare 4-210 
EIS - Numeric Move 4-213 
EIS multiword instructions 4-2, 4-8 
EIS single-word instructions 4-2, 

4-6 
extended instruction set (EIS) 

operations 4-1 

ENTRY 

Master Mode Entry 4-140 

EXCLUSIVE 

Boolean EXCLUSIVE OR 4-78 

Execute 4-138 

Execution 

Instruction execution 1-1 



EXPONENT 

Exponent Register (E) 3-4 

EXPONENT-ACCUMULATOR-QUOTIENT 
Exponent -Accumulator-Quotient 
Register (EAQ) 3-4 

EXTENDED 

extended instruction set (EIS) 

operations 4-1 
VIRTUAL ADDRESS FORMATION FOR 

EXTENDED INSTRUCTION SET 

EXTERNAL 

INTERRUPTS AND EXTERNAL FAULTS 



6-24 
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FAULT 

FAULT CYCLE SEQUENCE 7-1 
FAULT DESCRIPTIONS 7-4 
fault priority groups 7-3 
Fault Register (FR) - DPS and L68 
3-23 



FAULTS 

Faults and interrupts 1-3, 7-1 
INTERRUPTS AND EXTERNAL FAULTS 7- 

FEATURES 

PROCESSOR FEATURES 1-1 



FIELD 

Address Modifier (TAG) Field 
modification field 4-9 
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FIXED-P 
Fixed 
FIXED 
FIXED 
Fixed 
Fixed 
Fixed 

Fixed 



Fixed 
Fixed 
Fixed 
Fixed 
Fixed 



OINT 

Point 
-POINT 

POINT 
-Point 
-Point 
-Point 
4-36 
-Point 
4-25 
-Point 
-Point 
-Point 
-Point 

Point 



Addition 4-42 
ARITHMETIC 4-16 
BINARY DATA 2-4 
Comparison 4-64 
Data Movement Load 
Data Movement Shift 

Data Movement Store 

Division 4-59 
Miscellaneous 4-69 
Multiplication 4-57 
Negate 4-62 
Subtraction 4-50 
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FLAGS 

edit flags 



4-247 



FLOATING-POINT 
Floating-Point 
FLOATING-POINT 
Floating-Point 
Floating-Point 

4-86 
Floating-Point 

4-87 
Floating-Point 
Floating-Point 
Floating-Point 
Floating-Point 
Floating-Point 
Floating-Point 
Floating-Point 



Addition 4-90 
BINARY DATA 2-6 
Compare 4-107 
Data Movement Load 

Dataata Movement Store 

Division 4-99 
Miscellaneous 4-109 
Multiplication 4-96 
Negate 4-103 
Normalize 4-104 
Round 4-105 
Subtraction 4-93 



FORMAT 

ALPHANUMERIC OPERAND DESCRIPTOR 

FORMAT 4-12 
BIT-STRING OPERAND DESCRIPTOR FORMAT 

4-15 
FORMAT OF INSTRUCTION 4-2 
NUMERIC OPERAND DESCRIPTOR FORMAT 

4-13 
OPERAND DESCRIPTOR INDIRECT POINTER 

FORMAT 4-11.1 
Page Table Word (PTW) Format 5-10 
Segment Descriptor Word (SDW) Format 
5-9 

FORMATION 

Common Computed Address Formation 

6-6 
Page Number Formation 5-3 
virtual address formation 6-1, 6-19 
VIRTUAL ADDRESS FORMATION FOR 

EXTENDED INSTRUCTION SET 6-24 
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FORMATS 

APPENDING UNIT DATA WORD FORMATS 

5-9 
INSTRUCTION WORD FORMATS 4-6 
unstructured formats 2-2 



INDIRECT (cont) 

OPERAND DESCRIPTOR INDIRECT POINTER 

FORMAT 4-11.1 
Register Then Indirect (ri) 
Modification 6-9 



FR 

Fault Register (FR) - DPS and L68 
3-23 

FRAMES 

page frames 1-2 

GENERAL 

General Computed Address 

Modification Types 6-5 

GENERATION 

effective segment number generation 

6-22 
Main Memory Address Generation 5-3, 

5-5 

GROUPS 

fault priority groups 7-3 

HISTORY 

Appending Unit (APU) History 

Register - DPS 8M 3-51 
Appending Unit (APU) History 

Register - DPS and L68 3-49 
Control Unit (CU) History Register - 

DPS 8M 3-39 
Control Unit (CU) History Register - 

DPS and L68 3-37 
Decimal unit history register 3-43 
Operations Unit (OU) History 

Register 3-41 

ILLEGAL 

illegal modifier 4-6 

IN 

Cache Memory Control in Segment 
Descriptor Words 9-6 

INDEX 

Index Register (Xn) 3-5 
Index Values 4-4 

INDICATOR 

Indicator Register (IR) 3-5 

INDICATORS 

EIS - Bit String Set Indicators 
4-224 

INDIRECT 

indirect pointers 4-1 1 
Indirect Then Register (ir) 

Modification 6-10 
Indirect Then Tally (it) 

Modification 6-12 
INDIRECT TO POINTER (ITP) 

MODIFICATION 6-20 
INDIRECT TO SEGMENT (ITS) 

MODIFICATION 6-2 1 
indirect word 4-8 



INSERTION 

edit insertion table 



4-246 



INSTRUCTION 

extended instruction set (EIS) 

operations 4-1 
FORMAT OF INSTRUCTION 4-2 
Instruction execution 1-1 
INSTRUCTION WORD FORMATS 4-6 
VIRTUAL ADDRESS FORMATION FOR 

EXTENDED INSTRUCTION SET 6-24 

INSTRUCTIONS 

basic instructions 4-6 
BOOLEAN OPERATION INSTRUCTIONS 4-70 
EIS multiword instructions 4-2, 4-8 
EIS single-word instructions 4-2, 

4-6 
machine instructions 4-1 

INTERRUPTS 

Faults and interrupts 1-3, 7-1 
INTERRUPTS AND EXTERNAL FAULTS 7-8 



IR 



Indicator Register (IR) 3-5 
Indirect Then Register (ir) 
Modification 6-10 



IT 



Indirect Then Tally (it) 
Modification 6-12 



ITP 



INDIRECT TO POINTER (ITP) 
MODIFICATION 6-20 



ITS 



INDIRECT TO SEGMENT (ITS) 
MODIFICATION 6-21 

L68 

Appending Unit (APU) History 

Register - DPS and L68 3-49 
Cache Mode Register (CMR) - DPS and 

L68 3-32 
Configuration Switch Data - DPS and 

L68 3-54 
Control Unit (CU) History Register - 

DPS and L68 3-37 
Fault Register (FR) - DPS and L68 

3-23 
Mode Register (MR) - DPS and L6L68 

3-27 

LOAD 

EIS - Address Register Load 4-177 
Fixed-Point Data Movement Load 4-16 
Floating-Point Data Movement Load 

4-86 
Pointer Register Data Movement Load 

4-124 
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LOAD (cont) 

Register Load 4-157 

LOCALITY 

Locality of reference 9-1 

MACHINE 

machine instructions 4-1 

MAIN 

Main memory 9-1 

Main Memory Address Generation 5-3, 

5-5 
Main Memory Addresses 4-4 
modes of main memory addressing 1-3 

MAP 

Micro Operation Code Assignment Map 
4-257 

MASTER 

Master Mode Entry 4-140 

MECHANISM 

APPENDING UNIT OPERATION WITH RING 
MECHANISM 8-3 

MEMORY 

Associative Memory Assembly 1-4 
Cache Memory Control in Segment 

Descriptor Words 9-6 
Main memory 9-1 
Main Memory Address Generation 5-3, 

5-5 
Main Memory Addresses 4-4 
modes of main memory addressing 1-3 
Page Table Word Associative Memory 

(PTWAM) 3-20 
Privileged - Clear Associative 

Memory 4-168 
Segment Descriptor Word Associative 

Memory (SDWAM) - DPS/L68 and 

DPS 8M 3-18 

MICRO 

Micro Operation Code Assignment Map 
4-257 

MISCELLANEOUS 

Fixed-Point Miscellaneous 4-69 
Floating-Point Miscellaneous 4-109 
Pointer Register Miscellaneous 

4-135 
Privileged - Miscellaneous 4-176 

MNEMONIC 

mnemonic code 4-2 

MODE 

Absolute Mode 1-3 

append mode 5-2 

BAR mode 1-4 

Cache Mode Register (CMR) - DPS and 

L68 3-32 
Master Mode Entry 4-140 
Mode Register (MR) - DPS and L68 

3-27 
normal mode 1-3 



MODE (cont) 

privileged mode 1-3 

MODES 

CHANGING ADDRESSING MODES 5-5 
modes of main memory addressing 1-3 

Modification 

Address modification 1-2 
General Computed Address 

Modification Types 6-5 
Indirect Then Register (ir) 

Modification 6-10 
Indirect Then Tally (it) 

Modification 6-12 
INDIRECT TO POINTER (ITP) 

MODIFICATION 6-20 
INDIRECT TO SEGMENT (ITS) 

MODIFICATION 6-21 
modification field 4-9 
Register (r) Modification 6-6 
Register Then Indirect (ri) 

Modification 6-9 

MODIFIER 

Address Modifier (TAG) Field 6-3 
illegal modifier 4-6 

MODIFIERS 

special address modifiers 6-19 

MOVE 

EIS - Alphanumeric Move 4-202 
EIS - Numeric Move 4-213 

MOVEMENT 

Fixed-Point Data Movement Load 4-16 
Fixed-Point Data Movement Shift 

4-36 
Fixed-Point Data Movement Store 

4-25 
Floating-Point Data Movement Load 

4-86 
Floating-Point Data Movement Store 

4-87 
Pointer Register Data Movement Load 

4-124 
Pointer Register Data Movement Store 
4-130 

MR 

Mode Register (MR) - DPS and L68 
3-27 

MULTIPLICATION 

EIS - Decimal Multiplication 4-239 
Fixed-Point Multiplication 4-57 
Floating-Point Multiplication 4-96 

MULTIWORD 

EIS multiword instructions 4-2, 4-8 

MVE 

MVNE and MVE Differences 4-248 

MVNE 

MVNE and MVE Differences 4-248 
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NEGATE 

Fixed-Point Negate 4-62 
Floating-Point Negate 1-103 

NO 

No Operation 1-113 

Normal 

Normal mode 1-3 

NORMALIZE 

Floating-Point Normalize 1-104 

NOT 

Boolean Comparative NOT 4-81 

NOTATION 

NOTATION AND SYMBOLS 4-4 

NUMBER 

binary number system 2-1 
effective segment number generation 

6-22 
Page Number Formation 5-3 

NUMERIC 

EIS - Numeric Compare 4-210 
EIS - Numeric Move 4-213 
NUMERIC EDIT 4-248 
NUMERIC OPERAND DESCRIPTOR FORMAT 
4-13 

OPERAND 

ALPHANUMERIC OPERAND DESCRIPTOR 

FORMAT 4-12 
BIT-STRING OPERAND DESCRIPTOR FORMAT 

4-15 
NUMERIC OPERAND DESCRIPTOR FORMAT 

4-13 
OPERAND DESCRIPTOR INDIRECT POINTER 
FORMAT 1-11.1 

OPERATION 

APPENDING UNIT OPERATION WITH RING 

MECHANISM 8-3 
BOOLEAN OPERATION INSTRUCTIONS 1-70 
Micro Operation Code Assignment Map 

1-257 
No Operation 1-113 
Operation Unit 1-5 

OPERATIONS 

basic operations 1-1 
extended instruction set (EIS) 

operations 4-1 
Operations Unit (OU) History 
Register 3-41 

OR 

Boolean EXCLUSIVE OR 4-78 
Boolean OR 4-74 

OTHER 

Other Symbols 4-5 



OU 



Operations Unit (OU) History 
Register 3-41 



OVERLENGTH 

Overlength Registers 2-8 

PAGE 

page frames 1-2 
Page Number Formation 5-3 
Page Table Word (PTW) Format 5-10 
Page Table Word Associative Memory 
(PTWAM) 3-20 

PAGING 5-3 

Segmentation and Paging 1-2 

PARITY 

DATA PARITY 2-4 

POINTER 

INDIRECT TO POINTER (ITP) 

MODIFICATION 6-20 
OPERAND DESCRIPTOR INDIRECT POINTER 

FORMAT 4-11.1 
Pointer Register (PRn) 3-11 
Pointer Register Address Arithmetic 

4-134 
Pointer Register Data Movement Load 

4-124 
Pointer Register Data Movement Store 

4-130 
Pointer Register Miscellaneous 

4-135 
Procedure Pointer Register (PPR) 

3-14 
Temporary Pointer Register (TPR) 

3-15 

POINTERS 

indirect pointers 4-11 

PPR 

Procedure Pointer Register (PPR) 
3-14 

PRIORITY 

fault priority groups 7-3 

PRIVILEGED 

Privileged - Clear Associative 

Memory 4-168 
Privileged - Configuration and 

Status 4-170 
Privileged - Miscellaneous 4-176 
Privileged - Register Store 1-163 
Privileged - System Control 1-173 
privileged mode 1-3 

Privileged - Register Load 1-157.1 

PRN 

Pointer Register (PRn) 3-11 

PROCEDURE 

Procedure Pointer Register (PPR) 

3-1* 

PROCESSOR 1-1 

PROCESSOR FEATURES 1-1 
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PTW 

Page Table Word (PTW) Format 5-10 

PTWAM 

(PTWAH) registers 1-4 
Page Table Word Associative Memory 
(PTWAM) 3-20 



Quotient Register (Q) 3-3 

QUOTIENT 

Quotient Register (Q) 3-3 



Register (r) Modification 6-6 

RALR 

Ring Alarm Register (RALR) 3-10 



REGISTER (cont) 

Pointer Register Data Movement Store 

4-130 
Pointer Register Miscellaneous 

4-135 
Privileged - Register Store 4-163 
Procedure Pointer Register (PPR) 

3-14 
Quotient Register (Q) 3-3 
Register (r) Modification 6-6 
Register Load 4-157 
Register Then Indirect (ri) 

Modification 6-9 
Ring Alarm Register 4-153 
Ring Alarm Register (RALR) 3-10 
Store Base Address Register 4-154 
Temporary Pointer Register (TPR) 

3-15 
Timer Register (TR) 3-10 



REFERENCE 

Locality of reference 9- 



1 



REGISTER 

(PTWAM) registers 1-4 
(SDWAM) registers 1-4 
Accumulator Register (A) 3-2 
Accumulator-Quotient Register (AQ) 

3-3 
Address Register (ARn) 3-12 
Appending Unit (APU) History 

Register - DPS 8M 3-51 
Appending Unit (APU) History 

Register - DPS and L68 3-49 
base address register 1-4 
Base Address Register (BAR) 3-9 
Cache Mode Register (CMR) - DPS and 

L68 3-32 
Control Unit (CU) History Register - 

DPS 8M 3-39 
Control Unit (CU) History Register - 

DPS and L68 3-37 
Decimal unit history register 3-43 
Descriptor Segment Base Register 

(DSBR) 3-16 
EIS - Address Register Load 4-177 
EIS - Address Register Special 

Arithmetic 4-183 
EIS - Address Register Store 4-1 80 
Exponent Register (E) 3-4 
Exponent- Accumulator-Quotient 

Register (EAQ) 3-4 
Fault Register (FR) - DPS and L68 

3-23 
Index Register (Xn) 3-5 
Indicator Register (IR) 3-5 
Indirect Then Register (ir) 

Modification 6-10 
Mode Register (MR) - DPS and L68 

3-27 
Operations Unit (OU) History 

Register 3-41 
Overlength Registers 2-8 
Pointer Register (PRn) 3-11 
Pointer Register Address Arithmetic 

4-134 
Pointer Register Data Movement Load 

4-124 



Repeat 4-145 

RI 

Register Then Indirect (ri) 
Modification 6-9 

RING 

APPENDING UNIT OPERATION WITH RING 

MECHANISM 8-3 
Ring Alarm Register 4-153 
Ring Alarm Register (RALR) 3-10 

ROUND 

Floating-Point Round 4-105 

SDW 

Segment Descriptor Word (SDW) Format 
5-9 

SDWAM 

(SDWAM) registers 1-4 
Segment Descriptor Word Associative 
Memory (SDWAM) - DPS/L68 and 
DPS 8M 3-18 

SEGMENT 

Cache Memory Control in Segment 

Descriptor Words 9-6 
Descriptor Segment Base Register 

(DSBR) 3-16 
effective segment number generation 

6-22 
INDIRECT TO SEGMENT (ITS) 

MODIFICATION 6-21 
Segment Descriptor Word (SDW) Format 

5-9 
Segment Descriptor Word Associative 

Memory (SDWAM) - DPS/L68 and 

DPS 8M 3-18 
segment size 1-2 

Segment Descriptor Word 8-2 

SEGMENTATION 5-2 

Segmentation and Paging 1-2 

SEQUENCE 

FAULT CYCLE SEQUENCE 7-1 
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SEQUENCES 

Address Appending Sequences 5-6 

SET 

EIS - Bit String Set Indicators 

4-224 
extended instruction set (EIS) 

operations 4-1 
VIRTUAL ADDRESS FORMATION FOR 

EXTENDED INSTRUCTION SET 6-24 

SHIFT 

Fixed-Point Data Movement Shift 
4-36 

SINGLE-WORD 

EIS single-word instructions 4-2, 
4-6 

SIZE 

segment size T-2 

SPECIAL 

EIS - Address Register Special 

Arithmetic 4-183 
special address modifiers 6-19 

STATUS 

Privileged - Configuration and 
Status 4-170 

STORE 

EIS - Address Register Store 4-180 
Fixed-Point Data Movement Store 

4-25 
Floating-Point Data Movement Store 

4-87 
Pointer Register Data Movement Store 

4-130 
Privileged - Register Store 4-163 
Store Base Address Register 4-154 

STRING 

EIS - Bit String Combine 4-218 
EIS - Bit String Compare 4-222 
EIS - Bit String Set Indicators 
4-224 

SUBTRACTION 

EIS - Decimal Subtraction 4-236 
Fixed-Point Subtraction 4-50 
Floating-Point Subtraction 4-93 

SWITCH 

Configuration Switch Data - DPS 8m 

3-56 
Configuration Switch Data - DPS and 

L68 3-54 

SYMBOLS 

Abbreviations and Symbols 4-4 
NOTATION AND SYMBOLS 4-4 
Other Symbols 4-5 

SYSTEM 

binary number system 2-1 
Privileged - System Control 4-173 



TABLE 

edit insertion table 4-246 
Page Table Word (PTW) Format 5-10 
Page Table Word Associative Memory 
(PTWAM) 3-20 

tabs 4-8 

TAG 

Address Modifier (TAG) Field 6-3 

TALLY 

Indirect Then Tally (it) 
Modification 6-12 

TEMPORARY 

Temporary Pointer Register (TPR) 
3-15 

THEN 

Indirect Then Register (ir) 

Modification 6-10 
Indirect Then Tally (it) 

Modification 6-12 
Register Then Indirect (ri) 

Modification 6-9 

TIMER 

Timer Register (TR) 3-10 

TPR 

Temporary Pointer Register (TPR) 
3-15 

TR 

Timer Register (TR) 3-10 

Translation 4-155 

TYPES 

General Computed Address 

Modification Types 6-5 

UNIT 

Appending Unit 1-4 
Appending Unit (APU) History 

Register - DPS 8m 3-51 
Appending Unit (APU) History 

Register - DPS and L68 3-49 
APPENDING UNIT DATA WORD FORMATS 

5-9 
APPENDING UNIT OPERATION WITH RING 

MECHANISM 8-3 
Control Unit 1-4 
Control Unit (CU) History Register - 

DPS 8M 3-39 
Control Unit (CU) History Register • 

DPS and L68 3-37 
Control Unit Data 3-58 
Decimal Unit 1-5 
Decimal Unit Data 3-63 
Decimal unit history register 3-43 
Operation Unit 1-5 
Operations Unit (OU) History 

Register 3-11 

UNSTRUCTURED 

unstructured formats 2-2 
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VALUES 

Index Values 4-4 

VIRTUAL 

virtual address formation 6-1, 6-19 
VIRTUAL ADDRESS FORMATION FOR 

EXTENDED INSTRUCTION SET 6-24 

WORD 

APPENDING UNIT DATA WORD FORMATS 

5-9 
indirect word 4-8 
INSTRUCTION WORD FORMATS 4-6 
Page Table Word (PTW) Format 5-10 
Page Table Word Associative Memory 

(PTWAM) 3-20 
Segment Descriptor Word (SDW) Format 

5-9 
Segment Descriptor Word Associative 

Memory (SDWAM) - DPS/L68 and 

DPS 8M 3-18 

WORDS 

Cache Memory Control in Segment 
Descriptor Words 9-6 

XN 

Index Register (Xn) 3-5 
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